66
68
self._save_size_on_destroy(self, 'viz-window-size')
69
icon = self.render_icon(gtk.STOCK_INDEX, gtk.ICON_SIZE_BUTTON)
71
icon = self.render_icon_pixbuf(Gtk.STOCK_INDEX, Gtk.IconSize.BUTTON)
70
72
self.set_icon(icon)
72
gtk.accel_map_add_entry("<viz>/Go/Next Revision", gtk.keysyms.Up, gtk.gdk.MOD1_MASK)
73
gtk.accel_map_add_entry("<viz>/Go/Previous Revision", gtk.keysyms.Down, gtk.gdk.MOD1_MASK)
74
gtk.accel_map_add_entry("<viz>/View/Refresh", gtk.keysyms.F5, 0)
74
Gtk.AccelMap.add_entry("<viz>/Go/Next Revision", Gdk.KEY_Up, Gdk.ModifierType.MOD1_MASK)
75
Gtk.AccelMap.add_entry("<viz>/Go/Previous Revision", Gdk.KEY_Down, Gdk.ModifierType.MOD1_MASK)
76
Gtk.AccelMap.add_entry("<viz>/View/Refresh", Gdk.KEY_F5, 0)
76
self.accel_group = gtk.AccelGroup()
78
self.accel_group = Gtk.AccelGroup()
77
79
self.add_accel_group(self.accel_group)
79
if getattr(gtk.Action, 'set_tool_item_type', None) is not None:
80
# Not available before PyGtk-2.10
81
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)
81
self.prev_rev_action = Gtk.Action("prev-rev", "_Previous Revision", "Go to the previous revision", Gtk.STOCK_GO_DOWN)
84
82
self.prev_rev_action.set_accel_path("<viz>/Go/Previous Revision")
85
83
self.prev_rev_action.set_accel_group(self.accel_group)
86
84
self.prev_rev_action.connect("activate", self._back_clicked_cb)
87
85
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)
87
self.next_rev_action = Gtk.Action("next-rev", "_Next Revision", "Go to the next revision", Gtk.STOCK_GO_UP)
90
88
self.next_rev_action.set_accel_path("<viz>/Go/Next Revision")
91
89
self.next_rev_action.set_accel_group(self.accel_group)
92
90
self.next_rev_action.connect("activate", self._fwd_clicked_cb)
93
91
self.next_rev_action.connect_accelerator()
95
self.refresh_action = gtk.Action("refresh", "_Refresh", "Refresh view", gtk.STOCK_REFRESH)
93
self.refresh_action = Gtk.Action("refresh", "_Refresh", "Refresh view", Gtk.STOCK_REFRESH)
96
94
self.refresh_action.set_accel_path("<viz>/View/Refresh")
97
95
self.refresh_action.set_accel_group(self.accel_group)
98
96
self.refresh_action.connect("activate", self._refresh_clicked)
99
97
self.refresh_action.connect_accelerator()
99
self.vbox = self.construct()
103
101
def _save_size_on_destroy(self, widget, config_name):
104
102
"""Creates a hook that saves the size of widget to config option
105
103
config_name when the window is destroyed/closed."""
106
104
def save_size(src):
107
width, height = widget.allocation.width, widget.allocation.height
105
allocation = widget.get_allocation()
106
width, height = allocation.width, allocation.height
108
107
value = '%sx%s' % (width, height)
109
108
self.config.set_user_option(config_name, value)
110
109
self.connect("destroy", save_size)
115
114
def construct(self):
116
115
"""Construct the window contents."""
117
vbox = gtk.VBox(spacing=0)
116
vbox = Gtk.VBox(spacing=0)
120
self.paned = gtk.VPaned()
121
self.paned.pack1(self.construct_top(), resize=False, shrink=True)
122
self.paned.pack2(self.construct_bottom(), resize=True, shrink=False)
119
# order is important here
120
paned = self.construct_paned()
125
121
nav = self.construct_navigation()
126
122
menubar = self.construct_menubar()
127
vbox.pack_start(menubar, expand=False, fill=True)
128
vbox.pack_start(nav, expand=False, fill=True)
130
vbox.pack_start(self.paned, expand=True, fill=True)
131
vbox.set_focus_child(self.paned)
133
self.treeview.connect('revision-selected',
134
self._treeselection_changed_cb)
135
self.treeview.connect('revision-activated',
136
self._tree_revision_activated)
138
self.treeview.connect('tag-added', lambda w, t, r: self._update_tags())
124
vbox.pack_start(menubar, False, True, 0)
125
vbox.pack_start(nav, False, True, 0)
126
vbox.pack_start(paned, True, True, 0)
127
vbox.set_focus_child(paned)
134
def construct_paned(self):
135
"""Construct the main HPaned/VPaned contents."""
136
if self.config.get_user_option('viz-vertical') == 'True':
137
self.paned = Gtk.Paned.new(Gtk.Orientation.HORIZONTAL)
139
self.paned = Gtk.Paned.new(Gtk.Orientation.VERTICAL)
141
self.paned.pack1(self.construct_top(), resize=False, shrink=True)
142
self.paned.pack2(self.construct_bottom(), resize=True, shrink=False)
141
147
def construct_menubar(self):
142
menubar = gtk.MenuBar()
148
menubar = Gtk.MenuBar()
144
file_menu = gtk.Menu()
145
file_menuitem = gtk.MenuItem("_File")
150
file_menu = Gtk.Menu()
151
file_menuitem = Gtk.MenuItem.new_with_mnemonic("_File")
146
152
file_menuitem.set_submenu(file_menu)
148
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)
149
156
file_menu_close.connect('activate', lambda x: self.destroy())
151
file_menu_quit = gtk.ImageMenuItem(gtk.STOCK_QUIT, self.accel_group)
152
file_menu_quit.connect('activate', lambda x: gtk.main_quit())
158
file_menu_quit = Gtk.ImageMenuItem.new_from_stock(
159
Gtk.STOCK_QUIT, self.accel_group)
160
file_menu_quit.connect('activate', lambda x: Gtk.main_quit())
154
162
if self._parent is not None:
155
163
file_menu.add(file_menu_close)
156
164
file_menu.add(file_menu_quit)
158
edit_menu = gtk.Menu()
159
edit_menuitem = gtk.MenuItem("_Edit")
166
edit_menu = Gtk.Menu()
167
edit_menuitem = Gtk.MenuItem.new_with_mnemonic("_Edit")
160
168
edit_menuitem.set_submenu(edit_menu)
162
edit_menu_branchopts = gtk.MenuItem("Branch Settings")
170
edit_menu_branchopts = Gtk.MenuItem(label="Branch Settings")
163
171
edit_menu_branchopts.connect('activate', lambda x: PreferencesWindow(self.branch.get_config()).show())
165
edit_menu_globopts = gtk.MenuItem("Global Settings")
173
edit_menu_globopts = Gtk.MenuItem(label="Global Settings")
166
174
edit_menu_globopts.connect('activate', lambda x: PreferencesWindow().show())
168
176
edit_menu.add(edit_menu_branchopts)
169
177
edit_menu.add(edit_menu_globopts)
171
view_menu = gtk.Menu()
172
view_menuitem = gtk.MenuItem("_View")
179
view_menu = Gtk.Menu()
180
view_menuitem = Gtk.MenuItem.new_with_mnemonic("_View")
173
181
view_menuitem.set_submenu(view_menu)
175
183
view_menu_refresh = self.refresh_action.create_menu_item()
176
184
view_menu_refresh.connect('activate', self._refresh_clicked)
178
186
view_menu.add(view_menu_refresh)
179
view_menu.add(gtk.SeparatorMenuItem())
187
view_menu.add(Gtk.SeparatorMenuItem())
181
view_menu_toolbar = gtk.CheckMenuItem("Show Toolbar")
189
view_menu_toolbar = Gtk.CheckMenuItem(label="Show Toolbar")
182
190
view_menu_toolbar.set_active(True)
183
191
if self.config.get_user_option('viz-toolbar-visible') == 'False':
184
192
view_menu_toolbar.set_active(False)
185
193
self.toolbar.hide()
186
194
view_menu_toolbar.connect('toggled', self._toolbar_visibility_changed)
188
view_menu_compact = gtk.CheckMenuItem("Show Compact Graph")
196
view_menu_compact = Gtk.CheckMenuItem(label="Show Compact Graph")
189
197
view_menu_compact.set_active(self.compact_view)
190
198
view_menu_compact.connect('activate', self._brokenlines_toggled_cb)
192
view_menu_diffs = gtk.CheckMenuItem("Show Diffs")
200
view_menu_vertical = Gtk.CheckMenuItem(label="Side-by-side Layout")
201
view_menu_vertical.set_active(False)
202
if self.config.get_user_option('viz-vertical') == 'True':
203
view_menu_vertical.set_active(True)
204
view_menu_vertical.connect('toggled', self._vertical_layout)
206
view_menu_diffs = Gtk.CheckMenuItem(label="Show Diffs")
193
207
view_menu_diffs.set_active(False)
194
208
if self.config.get_user_option('viz-show-diffs') == 'True':
195
209
view_menu_diffs.set_active(True)
196
210
view_menu_diffs.connect('toggled', self._diff_visibility_changed)
198
view_menu_wide_diffs = gtk.CheckMenuItem("Wide Diffs")
212
view_menu_wide_diffs = Gtk.CheckMenuItem(label="Wide Diffs")
199
213
view_menu_wide_diffs.set_active(False)
200
214
if self.config.get_user_option('viz-wide-diffs') == 'True':
201
215
view_menu_wide_diffs.set_active(True)
202
216
view_menu_wide_diffs.connect('toggled', self._diff_placement_changed)
204
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")
205
220
view_menu_wrap_diffs.set_active(False)
206
221
if self.config.get_user_option('viz-wrap-diffs') == 'True':
207
222
view_menu_wrap_diffs.set_active(True)
229
247
col.connect('toggled', self._col_visibility_changed, name)
230
248
view_menu.add(col)
233
251
go_menu.set_accel_group(self.accel_group)
234
go_menuitem = gtk.MenuItem("_Go")
252
go_menuitem = Gtk.MenuItem.new_with_mnemonic("_Go")
235
253
go_menuitem.set_submenu(go_menu)
237
255
go_menu_next = self.next_rev_action.create_menu_item()
238
256
go_menu_prev = self.prev_rev_action.create_menu_item()
240
tag_image = gtk.Image()
258
tag_image = Gtk.Image()
241
259
tag_image.set_from_file(icon_path("tag-16.png"))
242
self.go_menu_tags = gtk.ImageMenuItem("_Tags")
260
self.go_menu_tags = Gtk.ImageMenuItem.new_with_mnemonic("_Tags")
243
261
self.go_menu_tags.set_image(tag_image)
244
262
self.treeview.connect('refreshed', lambda w: self._update_tags())
246
264
go_menu.add(go_menu_next)
247
265
go_menu.add(go_menu_prev)
248
go_menu.add(gtk.SeparatorMenuItem())
266
go_menu.add(Gtk.SeparatorMenuItem())
249
267
go_menu.add(self.go_menu_tags)
251
self.revision_menu = RevisionMenu(self.branch.repository, [], self.branch, parent=self)
252
revision_menuitem = gtk.MenuItem("_Revision")
269
self.revision_menu = RevisionMenu(self.branch.repository, [],
270
self.branch, parent=self)
271
revision_menuitem = Gtk.MenuItem.new_with_mnemonic("_Revision")
253
272
revision_menuitem.set_submenu(self.revision_menu)
255
branch_menu = gtk.Menu()
256
branch_menuitem = gtk.MenuItem("_Branch")
274
branch_menu = Gtk.Menu()
275
branch_menuitem = Gtk.MenuItem.new_with_mnemonic("_Branch")
257
276
branch_menuitem.set_submenu(branch_menu)
259
branch_menu.add(gtk.MenuItem("Pu_ll Revisions"))
260
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"))
263
282
from bzrlib.plugins import search
264
283
except ImportError:
265
284
mutter("Didn't find search plugin")
267
branch_menu.add(gtk.SeparatorMenuItem())
286
branch_menu.add(Gtk.SeparatorMenuItem())
269
branch_index_menuitem = gtk.MenuItem("_Index")
288
branch_index_menuitem = Gtk.MenuItem.new_with_mnemonic("_Index")
270
289
branch_index_menuitem.connect('activate', self._branch_index_cb)
271
290
branch_menu.add(branch_index_menuitem)
273
branch_search_menuitem = gtk.MenuItem("_Search")
292
branch_search_menuitem = Gtk.MenuItem.new_with_mnemonic("_Search")
274
293
branch_search_menuitem.connect('activate', self._branch_search_cb)
275
294
branch_menu.add(branch_search_menuitem)
277
help_menu = gtk.Menu()
278
help_menuitem = gtk.MenuItem("_Help")
296
help_menu = Gtk.Menu()
297
help_menuitem = Gtk.MenuItem.new_with_mnemonic("_Help")
279
298
help_menuitem.set_submenu(help_menu)
281
help_about_menuitem = gtk.ImageMenuItem(gtk.STOCK_ABOUT, self.accel_group)
300
help_about_menuitem = Gtk.ImageMenuItem.new_from_stock(
301
Gtk.STOCK_ABOUT, self.accel_group)
282
302
help_about_menuitem.connect('activate', self._about_dialog_cb)
284
304
help_menu.add(help_about_menuitem)
298
318
"""Construct the top-half of the window."""
299
319
# FIXME: Make broken_line_length configurable
301
self.treeview = TreeView(self.branch, self.start_revs, self.maxnum, self.compact_view)
321
self.treeview = TreeView(self.branch, self.start_revs, self.maxnum,
303
324
for col in ["revno", "date"]:
304
325
option = self.config.get_user_option(col + '-column-visible')
305
326
if option is not None:
306
self.treeview.set_property(col + '-column-visible', option == 'True')
327
self.treeview.set_property(col + '-column-visible',
308
330
self.treeview.set_property(col + '-column-visible', False)
310
332
self.treeview.show()
312
align = gtk.Alignment(0.0, 0.0, 1.0, 1.0)
334
align = Gtk.Alignment.new(0.0, 0.0, 1.0, 1.0)
313
335
align.set_padding(5, 0, 0, 0)
314
336
align.add(self.treeview)
315
337
# user-configured size
531
566
self.toolbar.hide()
532
567
self.config.set_user_option('viz-toolbar-visible', col.get_active())
569
def _vertical_layout(self, col):
570
"""Toggle the layout vertical/horizontal"""
571
self.config.set_user_option('viz-vertical', str(col.get_active()))
574
self.vbox.remove(old)
575
self.vbox.pack_start(
576
self.construct_paned(), True, True, 0)
577
self._make_diff_paned_nonzero_size()
578
self._make_diff_nonzero_size()
580
self.treeview.emit('revision-selected')
582
def _make_diff_paned_nonzero_size(self):
583
"""make sure the diff/revision pane isn't zero-width or zero-height"""
584
alloc = self.diff_paned.get_allocation()
585
if (alloc.width < 10) or (alloc.height < 10):
586
width, height = self.get_size()
587
self.diff_paned.set_size_request(width/3, int(height / 2.5))
534
589
def _make_diff_nonzero_size(self):
535
590
"""make sure the diff isn't zero-width or zero-height"""
536
591
alloc = self.diff.get_allocation()