39
def __init__(self, repository, revids, branch=None, wt=None, parent=None):
40
super(RevisionMenu, self).__init__()
40
def __init__(self, repository, revids, branch=None, wt=None):
41
super(RevisionPopupMenu, self).__init__()
42
42
self.branch = branch
43
43
self.repository = repository
45
self.set_revision_ids(revids)
47
def set_revision_ids(self, revids):
48
assert isinstance(revids, list)
49
for c in self.get_children():
51
45
self.revids = revids
52
46
self.create_items()
56
50
item = gtk.MenuItem("View _Changes")
57
51
item.connect('activate', self.show_diff)
60
55
item = gtk.MenuItem("_Push")
61
56
item.connect('activate', self.show_push)
64
60
item = gtk.MenuItem("_Tag Revision")
65
61
item.connect('activate', self.show_tag)
68
65
item = gtk.MenuItem("_Merge Directive")
69
66
item.connect('activate', self.store_merge_directive)
70
67
# FIXME: self.append(item)
72
item = gtk.MenuItem("_Send Merge Directive")
73
item.connect('activate', self.send_merge_directive)
77
71
item = gtk.MenuItem("_Revert to this revision")
78
72
item.connect('activate', self.revert)
83
76
def store_merge_directive(self, item):
84
77
from bzrlib.plugins.gtk.mergedirective import CreateMergeDirectiveDialog
85
78
window = CreateMergeDirectiveDialog(self.branch, self.revids[0])
88
def send_merge_directive(self, item):
89
from bzrlib.plugins.gtk.mergedirective import SendMergeDirectiveDialog
90
from cStringIO import StringIO
91
window = SendMergeDirectiveDialog(self.branch, self.revids[0])
92
if window.run() == gtk.RESPONSE_OK:
94
outf.writelines(window.get_merge_directive().to_lines())
95
mail_client = self.branch.get_config().get_mail_client()
96
mail_client.compose_merge_request(window.get_mail_to(), "[MERGE]",
100
81
def show_diff(self, item):
101
82
from bzrlib.plugins.gtk.diff import DiffWindow
102
window = DiffWindow(parent=self._parent)
103
parentids = self.repository.get_revision(self.revids[0]).parent_ids
83
window = DiffWindow(parent=self.parent)
84
parentids = self.repository.revision_parents(self.revids[0])
104
86
if len(parentids) == 0:
105
87
parentid = NULL_REVISION
107
89
parentid = parentids[0]
108
91
rev_tree = self.repository.revision_tree(self.revids[0])
109
92
parent_tree = self.repository.revision_tree(parentid)
110
93
window.set_diff(self.revids[0], rev_tree, parent_tree)
126
109
if response != gtk.RESPONSE_NONE:
129
112
if response == gtk.RESPONSE_OK:
130
113
self.emit('tag-added', dialog.tagname, dialog._revid)
134
117
def revert(self, item):
135
118
pb = ui.ui_factory.nested_progress_bar()
136
119
revision_tree = self.branch.repository.revision_tree(self.revids[0])