27
from bzrlib import (errors, ui)
24
from gi.repository import Gtk
25
from gi.repository import GObject
28
27
from bzrlib.revision import NULL_REVISION
30
class RevisionPopupMenu(gtk.Menu):
29
class RevisionMenu(Gtk.Menu):
34
gobject.SIGNAL_RUN_FIRST,
36
(gobject.TYPE_STRING, gobject.TYPE_STRING)
33
GObject.SignalFlags.RUN_FIRST,
35
(GObject.TYPE_STRING, GObject.TYPE_STRING)
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()
48
54
def create_items(self):
49
55
if len(self.revids) == 1:
50
item = gtk.MenuItem("View _Changes")
56
item = Gtk.MenuItem("View _Changes")
51
57
item.connect('activate', self.show_diff)
55
item = gtk.MenuItem("_Push")
60
item = Gtk.MenuItem("_Push")
56
61
item.connect('activate', self.show_push)
60
item = gtk.MenuItem("_Tag Revision")
64
item = Gtk.MenuItem("_Tag Revision")
61
65
item.connect('activate', self.show_tag)
65
item = gtk.MenuItem("_Merge Directive")
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
item = gtk.MenuItem("_Revert to this revision")
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.ResponseType.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)