18
17
from bzrlib.plugins.gtk import _i18n
19
from bzrlib.plugins.gtk.ui import GtkProgressBar, ProgressPanel
20
18
from linegraph import linegraph, same_branch
21
19
from graphcell import CellRendererGraph
22
20
from treemodel import TreeModel
23
21
from bzrlib.revision import NULL_REVISION
26
23
class TreeView(gtk.VBox):
28
25
__gproperties__ = {
93
93
(gobject.TYPE_PYOBJECT, gobject.TYPE_PYOBJECT)),
94
94
'tag-added': (gobject.SIGNAL_RUN_FIRST,
96
(gobject.TYPE_STRING, gobject.TYPE_STRING)),
97
'refreshed': (gobject.SIGNAL_RUN_FIRST, gobject.TYPE_NONE,
96
(gobject.TYPE_STRING, gobject.TYPE_STRING))
101
99
def __init__(self, branch, start, maxnum, compact=True):
111
109
gtk.VBox.__init__(self, spacing=0)
113
self.progress_widget = ProgressPanel()
114
self.pack_start(self.progress_widget, expand=False, fill=True)
115
if getattr(ui.ui_factory, "set_progress_bar_widget", None) is not None:
116
# We'are using our own ui, let's tell it to use our widget.
117
ui.ui_factory.set_progress_bar_widget(self.progress_widget)
111
self.pack_start(self.construct_loading_msg(), expand=False, fill=True)
112
self.connect('revisions-loaded',
113
lambda x: self.loading_msg_box.hide())
119
115
self.scrolled_window = gtk.ScrolledWindow()
120
116
self.scrolled_window.set_policy(gtk.POLICY_AUTOMATIC,
137
133
gobject.idle_add(self.populate)
139
self.connect("destroy", self._on_destroy)
141
def _on_destroy(self, *ignored):
143
if getattr(ui.ui_factory, "set_progress_bar_widget", None) is not None:
144
# We'are using our own ui, let's tell it to stop using our widget.
145
ui.ui_factory.set_progress_bar_widget(None)
135
self.connect("destroy", lambda x: self.branch.unlock())
147
137
def do_get_property(self, property):
148
138
if property.name == 'revno-column-visible':
158
148
elif property.name == 'branch':
159
149
return self.branch
160
150
elif property.name == 'revision':
161
return self.model.get_value(self.model.get_iter(self.path),
151
return self.model.get_value(self.iter, treemodel.REVISION)
163
152
elif property.name == 'revision-number':
164
return self.model.get_value(self.model.get_iter(self.path),
153
return self.model.get_value(self.iter, treemodel.REVNO)
166
154
elif property.name == 'children':
167
return self.model.get_value(self.model.get_iter(self.path),
155
return self.model.get_value(self.iter, treemodel.CHILDREN)
169
156
elif property.name == 'parents':
170
return self.model.get_value(self.model.get_iter(self.path),
157
return self.model.get_value(self.iter, treemodel.PARENTS)
173
159
raise AttributeError, 'unknown property %s' % property.name
194
180
"""Return revision id of currently selected revision, or None."""
195
181
return self.get_property('revision')
197
def has_revision_id(self, revision_id):
198
return (revision_id in self.index)
200
183
def set_revision(self, revision):
201
184
self.set_property('revision', revision)
293
277
should be broken.
296
if getattr(ui.ui_factory, "set_progress_bar_widget", None) is not None:
297
# We'are using our own ui, let's tell it to use our widget.
298
ui.ui_factory.set_progress_bar_widget(self.progress_widget)
299
self.progress_bar = ui.ui_factory.nested_progress_bar()
300
self.progress_bar.update("Loading ancestry graph", 0, 5)
304
broken_line_length = 32
306
broken_line_length = None
308
show_graph = self.graph_column.get_visible()
310
self.branch.lock_read()
311
(linegraphdata, index, columns_len) = linegraph(self.branch.repository.get_graph(),
319
self.model = TreeModel(self.branch, linegraphdata)
320
self.graph_cell.columns_len = columns_len
321
width = self.graph_cell.get_size(self.treeview)[2]
324
self.graph_column.set_fixed_width(width)
325
self.graph_column.set_max_width(width)
327
self.treeview.set_model(self.model)
329
if not revision or revision == NULL_REVISION:
330
self.treeview.set_cursor(0)
332
self.set_revision(revision)
334
self.emit('refreshed')
337
self.progress_bar.finished()
281
broken_line_length = 32
283
broken_line_length = None
285
show_graph = self.graph_column.get_visible()
287
self.branch.lock_read()
288
(linegraphdata, index, columns_len) = linegraph(self.branch.repository,
295
self.model = TreeModel(self.branch, linegraphdata)
296
self.graph_cell.columns_len = columns_len
297
width = self.graph_cell.get_size(self.treeview)[2]
300
self.graph_column.set_fixed_width(width)
301
self.graph_column.set_max_width(width)
303
self.treeview.set_model(self.model)
305
if not revision or revision == NULL_REVISION:
306
self.treeview.set_cursor(0)
308
self.set_revision(revision)
310
self.emit('revisions-loaded')
339
314
def construct_treeview(self):
340
315
self.treeview = gtk.TreeView()
347
322
if set_tooltip is not None:
348
323
set_tooltip(treemodel.MESSAGE)
350
self._prev_cursor_path = None
351
325
self.treeview.connect("cursor-changed",
352
326
self._on_selection_changed)
421
395
return self.treeview
397
def construct_loading_msg(self):
398
image_loading = gtk.image_new_from_stock(gtk.STOCK_REFRESH,
399
gtk.ICON_SIZE_BUTTON)
402
label_loading = gtk.Label(
403
_i18n("Please wait, loading ancestral graph..."))
404
label_loading.set_alignment(0.0, 0.5)
407
self.loading_msg_box = gtk.HBox()
408
self.loading_msg_box.set_spacing(5)
409
self.loading_msg_box.set_border_width(5)
410
self.loading_msg_box.pack_start(image_loading, False, False)
411
self.loading_msg_box.pack_start(label_loading, True, True)
412
self.loading_msg_box.show()
414
return self.loading_msg_box
423
416
def _on_selection_changed(self, treeview):
424
417
"""callback for when the treeview changes."""
425
418
(path, focus) = treeview.get_cursor()
426
if (path is not None) and (path != self._prev_cursor_path):
427
self._prev_cursor_path = path # avoid emitting twice per click
420
self.iter = self.model.get_iter(path)
429
421
self.emit('revision-selected')
431
423
def _on_revision_selected(self, widget, event):
432
from bzrlib.plugins.gtk.revisionmenu import RevisionMenu
424
from bzrlib.plugins.gtk.revisionmenu import RevisionPopupMenu
433
425
if event.button == 3:
434
menu = RevisionMenu(self.branch.repository,
426
menu = RevisionPopupMenu(self.branch.repository,
435
427
[self.get_revision().revision_id],
437
429
menu.connect('tag-added', lambda w, t, r: self.add_tag(t, r))