40
def __init__(self, repository, revids, branch=None, wt=None):
41
super(RevisionPopupMenu, self).__init__()
39
def __init__(self, repository, revids, branch=None, wt=None, parent=None):
40
super(RevisionMenu, 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():
45
51
self.revids = revids
46
52
self.create_items()
50
56
item = gtk.MenuItem("View _Changes")
51
57
item.connect('activate', self.show_diff)
55
60
item = gtk.MenuItem("_Push")
56
61
item.connect('activate', self.show_push)
60
64
item = gtk.MenuItem("_Tag Revision")
61
65
item.connect('activate', self.show_tag)
65
68
item = gtk.MenuItem("_Merge Directive")
66
69
item.connect('activate', self.store_merge_directive)
67
70
# FIXME: self.append(item)
72
item = gtk.MenuItem("_Send Merge Directive")
73
item.connect('activate', self.send_merge_directive)
71
77
item = gtk.MenuItem("_Revert to this revision")
72
78
item.connect('activate', self.revert)
76
83
def store_merge_directive(self, item):
77
84
from bzrlib.plugins.gtk.mergedirective import CreateMergeDirectiveDialog
78
85
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]",
81
100
def show_diff(self, item):
82
101
from bzrlib.plugins.gtk.diff import DiffWindow
83
window = DiffWindow(parent=self.parent)
84
parentids = self.repository.revision_parents(self.revids[0])
102
window = DiffWindow(parent=self._parent)
103
parentids = self.repository.get_revision(self.revids[0]).parent_ids
86
104
if len(parentids) == 0:
87
105
parentid = NULL_REVISION
89
107
parentid = parentids[0]
91
108
rev_tree = self.repository.revision_tree(self.revids[0])
92
109
parent_tree = self.repository.revision_tree(parentid)
93
110
window.set_diff(self.revids[0], rev_tree, parent_tree)
109
126
if response != gtk.RESPONSE_NONE:
112
129
if response == gtk.RESPONSE_OK:
113
130
self.emit('tag-added', dialog.tagname, dialog._revid)
117
134
def revert(self, item):
118
135
pb = ui.ui_factory.nested_progress_bar()
119
136
revision_tree = self.branch.repository.revision_tree(self.revids[0])