67
67
self._save_size_on_destroy(self, 'viz-window-size')
70
icon = self.render_icon(Gtk.STOCK_INDEX, Gtk.IconSize.BUTTON)
70
icon = self.render_icon(gtk.STOCK_INDEX, gtk.ICON_SIZE_BUTTON)
71
71
self.set_icon(icon)
73
Gtk.AccelMap.add_entry("<viz>/Go/Next Revision", Gdk.KEY_Up, Gdk.ModifierType.MOD1_MASK)
74
Gtk.AccelMap.add_entry("<viz>/Go/Previous Revision", Gdk.KEY_Down, Gdk.ModifierType.MOD1_MASK)
75
Gtk.AccelMap.add_entry("<viz>/View/Refresh", Gdk.KEY_F5, 0)
73
gtk.accel_map_add_entry("<viz>/Go/Next Revision", gtk.keysyms.Up, gtk.gdk.MOD1_MASK)
74
gtk.accel_map_add_entry("<viz>/Go/Previous Revision", gtk.keysyms.Down, gtk.gdk.MOD1_MASK)
75
gtk.accel_map_add_entry("<viz>/View/Refresh", gtk.keysyms.F5, 0)
77
self.accel_group = Gtk.AccelGroup()
77
self.accel_group = gtk.AccelGroup()
78
78
self.add_accel_group(self.accel_group)
80
if getattr(Gtk.Action, 'set_tool_item_type', None) is not None:
81
Gtk.Action.set_tool_item_type(Gtk.MenuToolButton)
80
if getattr(gtk.Action, 'set_tool_item_type', None) is not None:
81
# Not available before PyGtk-2.10
82
gtk.Action.set_tool_item_type(gtk.MenuToolButton)
83
self.prev_rev_action = Gtk.Action("prev-rev", "_Previous Revision", "Go to the previous revision", Gtk.STOCK_GO_DOWN)
84
self.prev_rev_action = gtk.Action("prev-rev", "_Previous Revision", "Go to the previous revision", gtk.STOCK_GO_DOWN)
84
85
self.prev_rev_action.set_accel_path("<viz>/Go/Previous Revision")
85
86
self.prev_rev_action.set_accel_group(self.accel_group)
86
87
self.prev_rev_action.connect("activate", self._back_clicked_cb)
87
88
self.prev_rev_action.connect_accelerator()
89
self.next_rev_action = Gtk.Action("next-rev", "_Next Revision", "Go to the next revision", Gtk.STOCK_GO_UP)
90
self.next_rev_action = gtk.Action("next-rev", "_Next Revision", "Go to the next revision", gtk.STOCK_GO_UP)
90
91
self.next_rev_action.set_accel_path("<viz>/Go/Next Revision")
91
92
self.next_rev_action.set_accel_group(self.accel_group)
92
93
self.next_rev_action.connect("activate", self._fwd_clicked_cb)
93
94
self.next_rev_action.connect_accelerator()
95
self.refresh_action = Gtk.Action("refresh", "_Refresh", "Refresh view", Gtk.STOCK_REFRESH)
96
self.refresh_action = gtk.Action("refresh", "_Refresh", "Refresh view", gtk.STOCK_REFRESH)
96
97
self.refresh_action.set_accel_path("<viz>/View/Refresh")
97
98
self.refresh_action.set_accel_group(self.accel_group)
98
99
self.refresh_action.connect("activate", self._refresh_clicked)
99
100
self.refresh_action.connect_accelerator()
101
self.vbox = self.construct()
103
104
def _save_size_on_destroy(self, widget, config_name):
104
105
"""Creates a hook that saves the size of widget to config option
115
116
def construct(self):
116
117
"""Construct the window contents."""
117
vbox = Gtk.VBox(spacing=0)
118
vbox = gtk.VBox(spacing=0)
120
# order is important here
121
paned = self.construct_paned()
121
self.paned = gtk.VPaned()
122
self.paned.pack1(self.construct_top(), resize=False, shrink=True)
123
self.paned.pack2(self.construct_bottom(), resize=True, shrink=False)
122
126
nav = self.construct_navigation()
123
127
menubar = self.construct_menubar()
125
128
vbox.pack_start(menubar, expand=False, fill=True)
126
129
vbox.pack_start(nav, expand=False, fill=True)
127
vbox.pack_start(paned, expand=True, fill=True)
128
vbox.set_focus_child(paned)
131
vbox.pack_start(self.paned, expand=True, fill=True)
132
vbox.set_focus_child(self.paned)
134
self.treeview.connect('revision-selected',
135
self._treeselection_changed_cb)
136
self.treeview.connect('revision-activated',
137
self._tree_revision_activated)
139
self.treeview.connect('tag-added', lambda w, t, r: self._update_tags())
135
def construct_paned(self):
136
"""Construct the main HPaned/VPaned contents."""
137
if self.config.get_user_option('viz-vertical') == 'True':
138
self.paned = Gtk.HPaned()
140
self.paned = Gtk.VPaned()
142
self.paned.pack1(self.construct_top(), resize=False, shrink=True)
143
self.paned.pack2(self.construct_bottom(), resize=True, shrink=False)
148
142
def construct_menubar(self):
149
menubar = Gtk.MenuBar()
143
menubar = gtk.MenuBar()
151
file_menu = Gtk.Menu()
152
file_menuitem = Gtk.MenuItem("_File")
145
file_menu = gtk.Menu()
146
file_menuitem = gtk.MenuItem("_File")
153
147
file_menuitem.set_submenu(file_menu)
155
file_menu_close = Gtk.ImageMenuItem(Gtk.STOCK_CLOSE, self.accel_group)
149
file_menu_close = gtk.ImageMenuItem(gtk.STOCK_CLOSE, self.accel_group)
156
150
file_menu_close.connect('activate', lambda x: self.destroy())
158
file_menu_quit = Gtk.ImageMenuItem(Gtk.STOCK_QUIT, self.accel_group)
159
file_menu_quit.connect('activate', lambda x: Gtk.main_quit())
152
file_menu_quit = gtk.ImageMenuItem(gtk.STOCK_QUIT, self.accel_group)
153
file_menu_quit.connect('activate', lambda x: gtk.main_quit())
161
155
if self._parent is not None:
162
156
file_menu.add(file_menu_close)
163
157
file_menu.add(file_menu_quit)
165
edit_menu = Gtk.Menu()
166
edit_menuitem = Gtk.MenuItem("_Edit")
159
edit_menu = gtk.Menu()
160
edit_menuitem = gtk.MenuItem("_Edit")
167
161
edit_menuitem.set_submenu(edit_menu)
169
edit_menu_branchopts = Gtk.MenuItem("Branch Settings")
163
edit_menu_branchopts = gtk.MenuItem("Branch Settings")
170
164
edit_menu_branchopts.connect('activate', lambda x: PreferencesWindow(self.branch.get_config()).show())
172
edit_menu_globopts = Gtk.MenuItem("Global Settings")
166
edit_menu_globopts = gtk.MenuItem("Global Settings")
173
167
edit_menu_globopts.connect('activate', lambda x: PreferencesWindow().show())
175
169
edit_menu.add(edit_menu_branchopts)
176
170
edit_menu.add(edit_menu_globopts)
178
view_menu = Gtk.Menu()
179
view_menuitem = Gtk.MenuItem("_View")
172
view_menu = gtk.Menu()
173
view_menuitem = gtk.MenuItem("_View")
180
174
view_menuitem.set_submenu(view_menu)
182
176
view_menu_refresh = self.refresh_action.create_menu_item()
183
177
view_menu_refresh.connect('activate', self._refresh_clicked)
185
179
view_menu.add(view_menu_refresh)
186
view_menu.add(Gtk.SeparatorMenuItem())
180
view_menu.add(gtk.SeparatorMenuItem())
188
view_menu_toolbar = Gtk.CheckMenuItem("Show Toolbar")
182
view_menu_toolbar = gtk.CheckMenuItem("Show Toolbar")
189
183
view_menu_toolbar.set_active(True)
190
184
if self.config.get_user_option('viz-toolbar-visible') == 'False':
191
185
view_menu_toolbar.set_active(False)
192
186
self.toolbar.hide()
193
187
view_menu_toolbar.connect('toggled', self._toolbar_visibility_changed)
195
view_menu_compact = Gtk.CheckMenuItem("Show Compact Graph")
189
view_menu_compact = gtk.CheckMenuItem("Show Compact Graph")
196
190
view_menu_compact.set_active(self.compact_view)
197
191
view_menu_compact.connect('activate', self._brokenlines_toggled_cb)
199
view_menu_vertical = Gtk.CheckMenuItem("Side-by-side Layout")
200
view_menu_vertical.set_active(False)
201
if self.config.get_user_option('viz-vertical') == 'True':
202
view_menu_vertical.set_active(True)
203
view_menu_vertical.connect('toggled', self._vertical_layout)
205
view_menu_diffs = Gtk.CheckMenuItem("Show Diffs")
193
view_menu_diffs = gtk.CheckMenuItem("Show Diffs")
206
194
view_menu_diffs.set_active(False)
207
195
if self.config.get_user_option('viz-show-diffs') == 'True':
208
196
view_menu_diffs.set_active(True)
209
197
view_menu_diffs.connect('toggled', self._diff_visibility_changed)
211
view_menu_wide_diffs = Gtk.CheckMenuItem("Wide Diffs")
199
view_menu_wide_diffs = gtk.CheckMenuItem("Wide Diffs")
212
200
view_menu_wide_diffs.set_active(False)
213
201
if self.config.get_user_option('viz-wide-diffs') == 'True':
214
202
view_menu_wide_diffs.set_active(True)
215
203
view_menu_wide_diffs.connect('toggled', self._diff_placement_changed)
217
view_menu_wrap_diffs = Gtk.CheckMenuItem("Wrap _Long Lines in Diffs")
205
view_menu_wrap_diffs = gtk.CheckMenuItem("Wrap _Long Lines in Diffs")
218
206
view_menu_wrap_diffs.set_active(False)
219
207
if self.config.get_user_option('viz-wrap-diffs') == 'True':
220
208
view_menu_wrap_diffs.set_active(True)
243
230
col.connect('toggled', self._col_visibility_changed, name)
244
231
view_menu.add(col)
247
234
go_menu.set_accel_group(self.accel_group)
248
go_menuitem = Gtk.MenuItem("_Go")
235
go_menuitem = gtk.MenuItem("_Go")
249
236
go_menuitem.set_submenu(go_menu)
251
238
go_menu_next = self.next_rev_action.create_menu_item()
252
239
go_menu_prev = self.prev_rev_action.create_menu_item()
254
tag_image = Gtk.Image()
241
tag_image = gtk.Image()
255
242
tag_image.set_from_file(icon_path("tag-16.png"))
256
self.go_menu_tags = Gtk.ImageMenuItem("_Tags")
243
self.go_menu_tags = gtk.ImageMenuItem("_Tags")
257
244
self.go_menu_tags.set_image(tag_image)
258
245
self.treeview.connect('refreshed', lambda w: self._update_tags())
260
247
go_menu.add(go_menu_next)
261
248
go_menu.add(go_menu_prev)
262
go_menu.add(Gtk.SeparatorMenuItem())
249
go_menu.add(gtk.SeparatorMenuItem())
263
250
go_menu.add(self.go_menu_tags)
265
self.revision_menu = RevisionMenu(self.branch.repository, [],
266
self.branch, parent=self)
267
revision_menuitem = Gtk.MenuItem("_Revision")
252
self.revision_menu = RevisionMenu(self.branch.repository, [], self.branch, parent=self)
253
revision_menuitem = gtk.MenuItem("_Revision")
268
254
revision_menuitem.set_submenu(self.revision_menu)
270
branch_menu = Gtk.Menu()
271
branch_menuitem = Gtk.MenuItem("_Branch")
256
branch_menu = gtk.Menu()
257
branch_menuitem = gtk.MenuItem("_Branch")
272
258
branch_menuitem.set_submenu(branch_menu)
274
branch_menu.add(Gtk.MenuItem("Pu_ll Revisions"))
275
branch_menu.add(Gtk.MenuItem("Pu_sh Revisions"))
260
branch_menu.add(gtk.MenuItem("Pu_ll Revisions"))
261
branch_menu.add(gtk.MenuItem("Pu_sh Revisions"))
278
264
from bzrlib.plugins import search
279
265
except ImportError:
280
266
mutter("Didn't find search plugin")
282
branch_menu.add(Gtk.SeparatorMenuItem())
268
branch_menu.add(gtk.SeparatorMenuItem())
284
branch_index_menuitem = Gtk.MenuItem("_Index")
270
branch_index_menuitem = gtk.MenuItem("_Index")
285
271
branch_index_menuitem.connect('activate', self._branch_index_cb)
286
272
branch_menu.add(branch_index_menuitem)
288
branch_search_menuitem = Gtk.MenuItem("_Search")
274
branch_search_menuitem = gtk.MenuItem("_Search")
289
275
branch_search_menuitem.connect('activate', self._branch_search_cb)
290
276
branch_menu.add(branch_search_menuitem)
292
help_menu = Gtk.Menu()
293
help_menuitem = Gtk.MenuItem("_Help")
278
help_menu = gtk.Menu()
279
help_menuitem = gtk.MenuItem("_Help")
294
280
help_menuitem.set_submenu(help_menu)
296
help_about_menuitem = Gtk.ImageMenuItem(Gtk.STOCK_ABOUT,
282
help_about_menuitem = gtk.ImageMenuItem(gtk.STOCK_ABOUT, self.accel_group)
298
283
help_about_menuitem.connect('activate', self._about_dialog_cb)
300
285
help_menu.add(help_about_menuitem)
314
299
"""Construct the top-half of the window."""
315
300
# FIXME: Make broken_line_length configurable
317
self.treeview = TreeView(self.branch, self.start_revs, self.maxnum,
302
self.treeview = TreeView(self.branch, self.start_revs, self.maxnum, self.compact_view)
320
304
for col in ["revno", "date"]:
321
305
option = self.config.get_user_option(col + '-column-visible')
322
306
if option is not None:
323
self.treeview.set_property(col + '-column-visible',
307
self.treeview.set_property(col + '-column-visible', option == 'True')
326
309
self.treeview.set_property(col + '-column-visible', False)
328
311
self.treeview.show()
330
align = Gtk.Alignment.new(0.0, 0.0, 1.0, 1.0)
313
align = gtk.Alignment(0.0, 0.0, 1.0, 1.0)
331
314
align.set_padding(5, 0, 0, 0)
332
315
align.add(self.treeview)
333
316
# user-configured size
513
492
_mod_index.index_url(self.branch.base)
515
494
def _branch_search_cb(self, w):
516
from bzrlib.plugins.search import (
518
errors as search_errors,
495
from bzrlib.plugins.search import index as _mod_index
520
496
from bzrlib.plugins.gtk.search import SearchDialog
497
from bzrlib.plugins.search import errors as search_errors
523
500
index = _mod_index.open_index_url(self.branch.base)
524
501
except search_errors.NoSearchIndex:
525
dialog = Gtk.MessageDialog(self, type=Gtk.MessageType.QUESTION,
526
buttons=Gtk.ButtonsType.OK_CANCEL,
502
dialog = gtk.MessageDialog(self, type=gtk.MESSAGE_QUESTION,
503
buttons=gtk.BUTTONS_OK_CANCEL,
527
504
message_format="This branch has not been indexed yet. "
529
if dialog.run() == Gtk.ResponseType.OK:
506
if dialog.run() == gtk.RESPONSE_OK:
531
508
index = _mod_index.index_url(self.branch.base)
555
532
self.toolbar.hide()
556
533
self.config.set_user_option('viz-toolbar-visible', col.get_active())
558
def _vertical_layout(self, col):
559
"""Toggle the layout vertical/horizontal"""
560
self.config.set_user_option('viz-vertical', str(col.get_active()))
563
self.vbox.remove(old)
564
self.vbox.pack_start(self.construct_paned(, True, True, 0), expand=True, fill=True)
565
self._make_diff_paned_nonzero_size()
566
self._make_diff_nonzero_size()
568
self.treeview.emit('revision-selected')
570
def _make_diff_paned_nonzero_size(self):
571
"""make sure the diff/revision pane isn't zero-width or zero-height"""
572
alloc = self.diff_paned.get_allocation()
573
if (alloc.width < 10) or (alloc.height < 10):
574
width, height = self.get_size()
575
self.diff_paned.set_size_request(width/3, int(height / 2.5))
577
535
def _make_diff_nonzero_size(self):
578
536
"""make sure the diff isn't zero-width or zero-height"""
579
537
alloc = self.diff.get_allocation()