68
67
self._save_size_on_destroy(self, 'viz-window-size')
71
icon = self.render_icon_pixbuf(Gtk.STOCK_INDEX, Gtk.IconSize.BUTTON)
70
icon = self.render_icon(Gtk.STOCK_INDEX, Gtk.IconSize.BUTTON)
72
71
self.set_icon(icon)
74
73
Gtk.AccelMap.add_entry("<viz>/Go/Next Revision", Gdk.KEY_Up, Gdk.ModifierType.MOD1_MASK)
78
77
self.accel_group = Gtk.AccelGroup()
79
78
self.add_accel_group(self.accel_group)
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)
81
84
self.prev_rev_action = Gtk.Action("prev-rev", "_Previous Revision", "Go to the previous revision", Gtk.STOCK_GO_DOWN)
82
85
self.prev_rev_action.set_accel_path("<viz>/Go/Previous Revision")
83
86
self.prev_rev_action.set_accel_group(self.accel_group)
102
105
"""Creates a hook that saves the size of widget to config option
103
106
config_name when the window is destroyed/closed."""
104
107
def save_size(src):
105
allocation = widget.get_allocation()
106
width, height = allocation.width, allocation.height
108
width, height = widget.allocation.width, widget.allocation.height
107
109
value = '%sx%s' % (width, height)
108
110
self.config.set_user_option(config_name, value)
109
111
self.connect("destroy", save_size)
121
123
nav = self.construct_navigation()
122
124
menubar = self.construct_menubar()
124
vbox.pack_start(menubar, False, True, 0)
125
vbox.pack_start(nav, False, True, 0)
126
vbox.pack_start(paned, True, True, 0)
126
vbox.pack_start(menubar, expand=False, fill=True)
127
vbox.pack_start(nav, expand=False, fill=True)
128
vbox.pack_start(paned, expand=True, fill=True)
127
129
vbox.set_focus_child(paned)
134
136
def construct_paned(self):
135
137
"""Construct the main HPaned/VPaned contents."""
136
138
if self.config.get_user_option('viz-vertical') == 'True':
137
self.paned = Gtk.Paned.new(Gtk.Orientation.HORIZONTAL)
139
self.paned = Gtk.HPaned()
139
self.paned = Gtk.Paned.new(Gtk.Orientation.VERTICAL)
141
self.paned = Gtk.VPaned()
141
143
self.paned.pack1(self.construct_top(), resize=False, shrink=True)
142
144
self.paned.pack2(self.construct_bottom(), resize=True, shrink=False)
148
150
menubar = Gtk.MenuBar()
150
152
file_menu = Gtk.Menu()
151
file_menuitem = Gtk.MenuItem.new_with_mnemonic("_File")
153
file_menuitem = Gtk.MenuItem("_File")
152
154
file_menuitem.set_submenu(file_menu)
154
file_menu_close = Gtk.ImageMenuItem.new_from_stock(
155
Gtk.STOCK_CLOSE, self.accel_group)
156
file_menu_close = Gtk.ImageMenuItem(Gtk.STOCK_CLOSE, self.accel_group)
156
157
file_menu_close.connect('activate', lambda x: self.destroy())
158
file_menu_quit = Gtk.ImageMenuItem.new_from_stock(
159
Gtk.STOCK_QUIT, self.accel_group)
159
file_menu_quit = Gtk.ImageMenuItem(Gtk.STOCK_QUIT, self.accel_group)
160
160
file_menu_quit.connect('activate', lambda x: Gtk.main_quit())
162
162
if self._parent is not None:
164
164
file_menu.add(file_menu_quit)
166
166
edit_menu = Gtk.Menu()
167
edit_menuitem = Gtk.MenuItem.new_with_mnemonic("_Edit")
167
edit_menuitem = Gtk.MenuItem("_Edit")
168
168
edit_menuitem.set_submenu(edit_menu)
170
edit_menu_branchopts = Gtk.MenuItem(label="Branch Settings")
170
edit_menu_branchopts = Gtk.MenuItem("Branch Settings")
171
171
edit_menu_branchopts.connect('activate', lambda x: PreferencesWindow(self.branch.get_config()).show())
173
edit_menu_globopts = Gtk.MenuItem(label="Global Settings")
173
edit_menu_globopts = Gtk.MenuItem("Global Settings")
174
174
edit_menu_globopts.connect('activate', lambda x: PreferencesWindow().show())
176
176
edit_menu.add(edit_menu_branchopts)
177
177
edit_menu.add(edit_menu_globopts)
179
179
view_menu = Gtk.Menu()
180
view_menuitem = Gtk.MenuItem.new_with_mnemonic("_View")
180
view_menuitem = Gtk.MenuItem("_View")
181
181
view_menuitem.set_submenu(view_menu)
183
183
view_menu_refresh = self.refresh_action.create_menu_item()
186
186
view_menu.add(view_menu_refresh)
187
187
view_menu.add(Gtk.SeparatorMenuItem())
189
view_menu_toolbar = Gtk.CheckMenuItem(label="Show Toolbar")
189
view_menu_toolbar = Gtk.CheckMenuItem("Show Toolbar")
190
190
view_menu_toolbar.set_active(True)
191
191
if self.config.get_user_option('viz-toolbar-visible') == 'False':
192
192
view_menu_toolbar.set_active(False)
193
193
self.toolbar.hide()
194
194
view_menu_toolbar.connect('toggled', self._toolbar_visibility_changed)
196
view_menu_compact = Gtk.CheckMenuItem(label="Show Compact Graph")
196
view_menu_compact = Gtk.CheckMenuItem("Show Compact Graph")
197
197
view_menu_compact.set_active(self.compact_view)
198
198
view_menu_compact.connect('activate', self._brokenlines_toggled_cb)
200
view_menu_vertical = Gtk.CheckMenuItem(label="Side-by-side Layout")
200
view_menu_vertical = Gtk.CheckMenuItem("Side-by-side Layout")
201
201
view_menu_vertical.set_active(False)
202
202
if self.config.get_user_option('viz-vertical') == 'True':
203
203
view_menu_vertical.set_active(True)
204
204
view_menu_vertical.connect('toggled', self._vertical_layout)
206
view_menu_diffs = Gtk.CheckMenuItem(label="Show Diffs")
206
view_menu_diffs = Gtk.CheckMenuItem("Show Diffs")
207
207
view_menu_diffs.set_active(False)
208
208
if self.config.get_user_option('viz-show-diffs') == 'True':
209
209
view_menu_diffs.set_active(True)
210
210
view_menu_diffs.connect('toggled', self._diff_visibility_changed)
212
view_menu_wide_diffs = Gtk.CheckMenuItem(label="Wide Diffs")
212
view_menu_wide_diffs = Gtk.CheckMenuItem("Wide Diffs")
213
213
view_menu_wide_diffs.set_active(False)
214
214
if self.config.get_user_option('viz-wide-diffs') == 'True':
215
215
view_menu_wide_diffs.set_active(True)
216
216
view_menu_wide_diffs.connect('toggled', self._diff_placement_changed)
218
view_menu_wrap_diffs = Gtk.CheckMenuItem.new_with_mnemonic(
219
"Wrap _Long Lines in Diffs")
218
view_menu_wrap_diffs = Gtk.CheckMenuItem("Wrap _Long Lines in Diffs")
220
219
view_menu_wrap_diffs.set_active(False)
221
220
if self.config.get_user_option('viz-wrap-diffs') == 'True':
222
221
view_menu_wrap_diffs.set_active(True)
231
230
view_menu.add(view_menu_wrap_diffs)
232
231
view_menu.add(Gtk.SeparatorMenuItem())
234
self.mnu_show_revno_column = Gtk.CheckMenuItem.new_with_mnemonic(
235
"Show Revision _Number Column")
236
self.mnu_show_date_column = Gtk.CheckMenuItem.new_with_mnemonic(
233
self.mnu_show_revno_column = Gtk.CheckMenuItem("Show Revision _Number Column")
234
self.mnu_show_date_column = Gtk.CheckMenuItem("Show _Date Column")
239
236
# Revision numbers are pointless if there are multiple branches
240
237
if len(self.start_revs) > 1:
250
247
go_menu = Gtk.Menu()
251
248
go_menu.set_accel_group(self.accel_group)
252
go_menuitem = Gtk.MenuItem.new_with_mnemonic("_Go")
249
go_menuitem = Gtk.MenuItem("_Go")
253
250
go_menuitem.set_submenu(go_menu)
255
252
go_menu_next = self.next_rev_action.create_menu_item()
258
255
tag_image = Gtk.Image()
259
256
tag_image.set_from_file(icon_path("tag-16.png"))
260
self.go_menu_tags = Gtk.ImageMenuItem.new_with_mnemonic("_Tags")
257
self.go_menu_tags = Gtk.ImageMenuItem("_Tags")
261
258
self.go_menu_tags.set_image(tag_image)
262
259
self.treeview.connect('refreshed', lambda w: self._update_tags())
269
266
self.revision_menu = RevisionMenu(self.branch.repository, [],
270
267
self.branch, parent=self)
271
revision_menuitem = Gtk.MenuItem.new_with_mnemonic("_Revision")
268
revision_menuitem = Gtk.MenuItem("_Revision")
272
269
revision_menuitem.set_submenu(self.revision_menu)
274
271
branch_menu = Gtk.Menu()
275
branch_menuitem = Gtk.MenuItem.new_with_mnemonic("_Branch")
272
branch_menuitem = Gtk.MenuItem("_Branch")
276
273
branch_menuitem.set_submenu(branch_menu)
278
branch_menu.add(Gtk.MenuItem.new_with_mnemonic("Pu_ll Revisions"))
279
branch_menu.add(Gtk.MenuItem.new_with_mnemonic("Pu_sh Revisions"))
275
branch_menu.add(Gtk.MenuItem("Pu_ll Revisions"))
276
branch_menu.add(Gtk.MenuItem("Pu_sh Revisions"))
282
279
from bzrlib.plugins import search
286
283
branch_menu.add(Gtk.SeparatorMenuItem())
288
branch_index_menuitem = Gtk.MenuItem.new_with_mnemonic("_Index")
285
branch_index_menuitem = Gtk.MenuItem("_Index")
289
286
branch_index_menuitem.connect('activate', self._branch_index_cb)
290
287
branch_menu.add(branch_index_menuitem)
292
branch_search_menuitem = Gtk.MenuItem.new_with_mnemonic("_Search")
289
branch_search_menuitem = Gtk.MenuItem("_Search")
293
290
branch_search_menuitem.connect('activate', self._branch_search_cb)
294
291
branch_menu.add(branch_search_menuitem)
296
293
help_menu = Gtk.Menu()
297
help_menuitem = Gtk.MenuItem.new_with_mnemonic("_Help")
294
help_menuitem = Gtk.MenuItem("_Help")
298
295
help_menuitem.set_submenu(help_menu)
300
help_about_menuitem = Gtk.ImageMenuItem.new_from_stock(
301
Gtk.STOCK_ABOUT, self.accel_group)
297
help_about_menuitem = Gtk.ImageMenuItem(Gtk.STOCK_ABOUT,
302
299
help_about_menuitem.connect('activate', self._about_dialog_cb)
304
301
help_menu.add(help_about_menuitem)
350
347
def construct_navigation(self):
351
348
"""Construct the navigation buttons."""
352
349
self.toolbar = Gtk.Toolbar()
353
self.toolbar.set_style(Gtk.ToolbarStyle.BOTH_HORIZ)
350
self.toolbar.set_style(Gtk.TOOLBAR_BOTH_HORIZ)
355
352
self.prev_button = self.prev_rev_action.create_tool_item()
356
353
self.toolbar.insert(self.prev_button, -1)
361
358
self.toolbar.insert(Gtk.SeparatorToolItem(), -1)
363
refresh_button = Gtk.ToolButton.new_from_stock(Gtk.STOCK_REFRESH)
360
refresh_button = Gtk.ToolButton(Gtk.STOCK_REFRESH)
364
361
refresh_button.connect('clicked', self._refresh_clicked)
365
362
self.toolbar.insert(refresh_button, -1)
371
368
def construct_bottom(self):
372
369
"""Construct the bottom half of the window."""
373
370
if self.config.get_user_option('viz-wide-diffs') == 'True':
374
self.diff_paned = Gtk.Paned.new(Gtk.Orientation.VERTICAL)
371
self.diff_paned = Gtk.VPaned()
376
self.diff_paned = Gtk.Paned.new(Gtk.Orientation.HORIZONTAL)
373
self.diff_paned = Gtk.HPaned()
377
374
(width, height) = self.get_size()
378
375
self.diff_paned.set_size_request(20, 20) # shrinkable
479
474
parent_id = parents[0]
481
if revision is not None:
482
self.show_diff(revision.revision_id, parent_id)
484
self.show_diff(NULL_REVISION)
476
self.show_diff(revision.revision_id, parent_id)
485
477
self.treeview.grab_focus()
487
479
def _back_clicked_cb(self, *args):
574
564
self.vbox.remove(old)
575
self.vbox.pack_start(
576
self.construct_paned(), True, True, 0)
565
self.vbox.pack_start(self.construct_paned(, True, True, 0), expand=True, fill=True)
577
566
self._make_diff_paned_nonzero_size()
578
567
self._make_diff_nonzero_size()
631
620
for tag, revid in tags:
632
621
tag_image = Gtk.Image()
633
622
tag_image.set_from_file(icon_path('tag-16.png'))
634
tag_item = Gtk.ImageMenuItem.new_with_mnemonic(
635
tag.replace('_', '__'))
623
tag_item = Gtk.ImageMenuItem(tag.replace('_', '__'))
636
624
tag_item.set_image(tag_image)
637
625
tag_item.connect('activate', self._tag_selected_cb, revid)
638
626
tag_item.set_sensitive(self.treeview.has_revision_id(revid))
657
645
return width, height
660
def show_diff(self, revid, parentid=NULL_REVISION):
648
def show_diff(self, revid=None, parentid=NULL_REVISION):
661
649
"""Open a new window to show a diff between the given revisions."""
662
650
from bzrlib.plugins.gtk.diff import DiffWindow
663
651
window = DiffWindow(parent=self)