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