/b-gtk/fix-viz

To get this branch, use:
bzr branch http://gegoxaren.bato24.eu/bzr/b-gtk/fix-viz

« back to all changes in this revision

Viewing changes to viz/branchwin.py

  • Committer: Vincent Ladeuil
  • Date: 2008-05-05 18:16:46 UTC
  • mto: (487.1.1 gtk)
  • mto: This revision was merged to the branch mainline in revision 490.
  • Revision ID: v.ladeuil+lp@free.fr-20080505181646-n95l8ltw2u6jtr26
Fix bug #187283 fix replacing _() by _i18n().

* genpot.sh 
Remove duplication. Add the ability to specify the genrated pot
file on command-line for debugging purposes.

* po/olive-gtk.pot:
Regenerated.

* __init__.py, branch.py, branchview/treeview.py, checkout.py,
commit.py, conflicts.py, diff.py, errors.py, initialize.py,
merge.py, nautilus-bzr.py, olive/__init__.py, olive/add.py,
olive/bookmark.py, olive/guifiles.py, olive/info.py,
olive/menu.py, olive/mkdir.py, olive/move.py, olive/remove.py,
olive/rename.py, push.py, revbrowser.py, status.py, tags.py:
Replace all calls to _() by calls to _i18n(), the latter being
defined in __init__.py and imported in the other modules from
there. This fix the problem encountered countless times when
running bzr selftest and getting silly error messages about
boolean not being callables.

Show diffs side-by-side

added added

removed removed

Lines of Context:
13
13
import gobject
14
14
import pango
15
15
 
16
 
from bzrlib.osutils import format_date
17
 
 
18
 
from graph import distances, graph, same_branch
19
 
from graphcell import CellRendererGraph
20
 
 
21
 
 
22
 
class BranchWindow(gtk.Window):
 
16
from bzrlib.plugins.gtk.window import Window
 
17
from bzrlib.plugins.gtk import icon_path
 
18
from bzrlib.plugins.gtk.tags import AddTagDialog
 
19
from bzrlib.plugins.gtk.preferences import PreferencesWindow
 
20
from bzrlib.plugins.gtk.branchview import TreeView, treemodel
 
21
from bzrlib.revision import Revision, NULL_REVISION
 
22
from bzrlib.config import BranchConfig
 
23
from bzrlib.config import GlobalConfig
 
24
 
 
25
class BranchWindow(Window):
23
26
    """Branch window.
24
27
 
25
28
    This object represents and manages a single window containing information
26
29
    for a particular branch.
27
30
    """
28
31
 
29
 
    def __init__(self):
30
 
        gtk.Window.__init__(self, gtk.WINDOW_TOPLEVEL)
 
32
    def __init__(self, branch, start_revs, maxnum, parent=None):
 
33
        """Create a new BranchWindow.
 
34
 
 
35
        :param branch: Branch object for branch to show.
 
36
        :param start_revs: Revision ids of top revisions.
 
37
        :param maxnum: Maximum number of revisions to display, 
 
38
                       None for no limit.
 
39
        """
 
40
 
 
41
        Window.__init__(self, parent=parent)
31
42
        self.set_border_width(0)
32
 
        self.set_title("bzrk")
 
43
 
 
44
        self.branch      = branch
 
45
        self.start_revs  = start_revs
 
46
        self.maxnum      = maxnum
 
47
        self.config      = GlobalConfig()
 
48
 
 
49
        if self.config.get_user_option('viz-compact-view') == 'yes':
 
50
            self.compact_view = True
 
51
        else:
 
52
            self.compact_view = False
 
53
 
 
54
        self.set_title(branch.nick + " - revision history")
33
55
 
34
56
        # Use three-quarters of the screen by default
35
57
        screen = self.get_screen()
42
64
        icon = self.render_icon(gtk.STOCK_INDEX, gtk.ICON_SIZE_BUTTON)
43
65
        self.set_icon(icon)
44
66
 
 
67
        gtk.accel_map_add_entry("<viz>/Go/Next Revision", gtk.keysyms.Up, gtk.gdk.MOD1_MASK)
 
68
        gtk.accel_map_add_entry("<viz>/Go/Previous Revision", gtk.keysyms.Down, gtk.gdk.MOD1_MASK)
 
69
 
45
70
        self.accel_group = gtk.AccelGroup()
46
71
        self.add_accel_group(self.accel_group)
47
72
 
 
73
        gtk.Action.set_tool_item_type(gtk.MenuToolButton)
 
74
 
 
75
        self.prev_rev_action = gtk.Action("prev-rev", "_Previous Revision", "Go to the previous revision", gtk.STOCK_GO_DOWN)
 
76
        self.prev_rev_action.set_accel_path("<viz>/Go/Previous Revision")
 
77
        self.prev_rev_action.set_accel_group(self.accel_group)
 
78
        self.prev_rev_action.connect("activate", self._back_clicked_cb)
 
79
        self.prev_rev_action.connect_accelerator()
 
80
 
 
81
        self.next_rev_action = gtk.Action("next-rev", "_Next Revision", "Go to the next revision", gtk.STOCK_GO_UP)
 
82
        self.next_rev_action.set_accel_path("<viz>/Go/Next Revision")
 
83
        self.next_rev_action.set_accel_group(self.accel_group)
 
84
        self.next_rev_action.connect("activate", self._fwd_clicked_cb)
 
85
        self.next_rev_action.connect_accelerator()
 
86
 
48
87
        self.construct()
49
88
 
 
89
    def set_revision(self, revid):
 
90
        self.treeview.set_revision_id(revid)
 
91
 
50
92
    def construct(self):
51
93
        """Construct the window contents."""
52
94
        vbox = gtk.VBox(spacing=0)
53
95
        self.add(vbox)
54
96
 
 
97
        self.paned = gtk.VPaned()
 
98
        self.paned.pack1(self.construct_top(), resize=True, shrink=False)
 
99
        self.paned.pack2(self.construct_bottom(), resize=False, shrink=True)
 
100
        self.paned.show()
 
101
 
 
102
        vbox.pack_start(self.construct_menubar(), expand=False, fill=True)
55
103
        vbox.pack_start(self.construct_navigation(), expand=False, fill=True)
56
 
 
57
 
        paned = gtk.VPaned()
58
 
        paned.pack1(self.construct_top(), resize=True, shrink=False)
59
 
        paned.pack2(self.construct_bottom(), resize=False, shrink=True)
60
 
        paned.show()
61
 
        vbox.pack_start(paned, expand=True, fill=True)
62
 
        vbox.set_focus_child(paned)
 
104
        
 
105
        vbox.pack_start(self.paned, expand=True, fill=True)
 
106
        vbox.set_focus_child(self.paned)
63
107
 
64
108
        vbox.show()
65
109
 
 
110
    def construct_menubar(self):
 
111
        menubar = gtk.MenuBar()
 
112
 
 
113
        file_menu = gtk.Menu()
 
114
        file_menuitem = gtk.MenuItem("_File")
 
115
        file_menuitem.set_submenu(file_menu)
 
116
 
 
117
        file_menu_close = gtk.ImageMenuItem(gtk.STOCK_CLOSE, self.accel_group)
 
118
        file_menu_close.connect('activate', lambda x: self.destroy())
 
119
        
 
120
        file_menu_quit = gtk.ImageMenuItem(gtk.STOCK_QUIT, self.accel_group)
 
121
        file_menu_quit.connect('activate', lambda x: gtk.main_quit())
 
122
        
 
123
        if self._parent is not None:
 
124
            file_menu.add(file_menu_close)
 
125
        file_menu.add(file_menu_quit)
 
126
 
 
127
        edit_menu = gtk.Menu()
 
128
        edit_menuitem = gtk.MenuItem("_Edit")
 
129
        edit_menuitem.set_submenu(edit_menu)
 
130
 
 
131
        edit_menu_find = gtk.ImageMenuItem(gtk.STOCK_FIND)
 
132
 
 
133
        edit_menu_branchopts = gtk.MenuItem("Branch Settings")
 
134
        edit_menu_branchopts.connect('activate', lambda x: PreferencesWindow(self.branch.get_config()).show())
 
135
 
 
136
        edit_menu_globopts = gtk.MenuItem("Global Settings")
 
137
        edit_menu_globopts.connect('activate', lambda x: PreferencesWindow().show())
 
138
 
 
139
        edit_menu.add(edit_menu_find)
 
140
        edit_menu.add(edit_menu_branchopts)
 
141
        edit_menu.add(edit_menu_globopts)
 
142
 
 
143
        view_menu = gtk.Menu()
 
144
        view_menuitem = gtk.MenuItem("_View")
 
145
        view_menuitem.set_submenu(view_menu)
 
146
 
 
147
        view_menu_toolbar = gtk.CheckMenuItem("Show Toolbar")
 
148
        view_menu_toolbar.set_active(True)
 
149
        view_menu_toolbar.connect('toggled', self._toolbar_visibility_changed)
 
150
 
 
151
        view_menu_compact = gtk.CheckMenuItem("Show Compact Graph")
 
152
        view_menu_compact.set_active(self.compact_view)
 
153
        view_menu_compact.connect('activate', self._brokenlines_toggled_cb)
 
154
 
 
155
        view_menu.add(view_menu_toolbar)
 
156
        view_menu.add(view_menu_compact)
 
157
        view_menu.add(gtk.SeparatorMenuItem())
 
158
 
 
159
        self.mnu_show_revno_column = gtk.CheckMenuItem("Show Revision _Number Column")
 
160
        self.mnu_show_date_column = gtk.CheckMenuItem("Show _Date Column")
 
161
 
 
162
        # Revision numbers are pointless if there are multiple branches
 
163
        if len(self.start_revs) > 1:
 
164
            self.mnu_show_revno_column.set_sensitive(False)
 
165
            self.treeview.set_property('revno-column-visible', False)
 
166
 
 
167
        for (col, name) in [(self.mnu_show_revno_column, "revno"), 
 
168
                            (self.mnu_show_date_column, "date")]:
 
169
            col.set_active(self.treeview.get_property(name + "-column-visible"))
 
170
            col.connect('toggled', self._col_visibility_changed, name)
 
171
            view_menu.add(col)
 
172
 
 
173
        go_menu = gtk.Menu()
 
174
        go_menu.set_accel_group(self.accel_group)
 
175
        go_menuitem = gtk.MenuItem("_Go")
 
176
        go_menuitem.set_submenu(go_menu)
 
177
        
 
178
        go_menu_next = self.next_rev_action.create_menu_item()
 
179
        go_menu_prev = self.prev_rev_action.create_menu_item()
 
180
 
 
181
        tag_image = gtk.Image()
 
182
        tag_image.set_from_file(icon_path("tag-16.png"))
 
183
        self.go_menu_tags = gtk.ImageMenuItem("_Tags")
 
184
        self.go_menu_tags.set_image(tag_image)
 
185
        self._update_tags()
 
186
 
 
187
        go_menu.add(go_menu_next)
 
188
        go_menu.add(go_menu_prev)
 
189
        go_menu.add(gtk.SeparatorMenuItem())
 
190
        go_menu.add(self.go_menu_tags)
 
191
 
 
192
        revision_menu = gtk.Menu()
 
193
        revision_menuitem = gtk.MenuItem("_Revision")
 
194
        revision_menuitem.set_submenu(revision_menu)
 
195
 
 
196
        revision_menu_diff = gtk.MenuItem("View Changes")
 
197
        revision_menu_diff.connect('activate', 
 
198
                self._menu_diff_cb)
 
199
        
 
200
        revision_menu_compare = gtk.MenuItem("Compare with...")
 
201
        revision_menu_compare.connect('activate',
 
202
                self._compare_with_cb)
 
203
 
 
204
        revision_menu_tag = gtk.MenuItem("Tag Revision")
 
205
        revision_menu_tag.connect('activate', self._tag_revision_cb)
 
206
 
 
207
        revision_menu.add(revision_menu_tag)
 
208
        revision_menu.add(revision_menu_diff)
 
209
        revision_menu.add(revision_menu_compare)
 
210
 
 
211
        branch_menu = gtk.Menu()
 
212
        branch_menuitem = gtk.MenuItem("_Branch")
 
213
        branch_menuitem.set_submenu(branch_menu)
 
214
 
 
215
        branch_menu.add(gtk.MenuItem("Pu_ll Revisions"))
 
216
        branch_menu.add(gtk.MenuItem("Pu_sh Revisions"))
 
217
 
 
218
        help_menu = gtk.Menu()
 
219
        help_menuitem = gtk.MenuItem("_Help")
 
220
        help_menuitem.set_submenu(help_menu)
 
221
 
 
222
        help_about_menuitem = gtk.ImageMenuItem(gtk.STOCK_ABOUT, self.accel_group)
 
223
        help_about_menuitem.connect('activate', self._about_dialog_cb)
 
224
 
 
225
        help_menu.add(help_about_menuitem)
 
226
 
 
227
        menubar.add(file_menuitem)
 
228
        menubar.add(edit_menuitem)
 
229
        menubar.add(view_menuitem)
 
230
        menubar.add(go_menuitem)
 
231
        menubar.add(revision_menuitem)
 
232
        menubar.add(branch_menuitem)
 
233
        menubar.add(help_menuitem)
 
234
        menubar.show_all()
 
235
 
 
236
        return menubar
 
237
 
66
238
    def construct_top(self):
67
239
        """Construct the top-half of the window."""
68
 
        scrollwin = gtk.ScrolledWindow()
69
 
        scrollwin.set_policy(gtk.POLICY_NEVER, gtk.POLICY_AUTOMATIC)
70
 
        scrollwin.set_shadow_type(gtk.SHADOW_IN)
71
 
        scrollwin.show()
72
 
 
73
 
        self.treeview = gtk.TreeView()
74
 
        self.treeview.set_rules_hint(True)
75
 
        self.treeview.set_search_column(4)
76
 
        self.treeview.connect("cursor-changed", self._treeview_cursor_cb)
77
 
        self.treeview.connect("row-activated", self._treeview_row_activated_cb)
78
 
        self.treeview.connect("button-release-event", 
79
 
                self._treeview_row_mouseclick)
80
 
        scrollwin.add(self.treeview)
 
240
        # FIXME: Make broken_line_length configurable
 
241
 
 
242
        self.treeview = TreeView(self.branch, self.start_revs, self.maxnum, self.compact_view)
 
243
 
 
244
        self.treeview.connect('revision-selected',
 
245
                self._treeselection_changed_cb)
 
246
        self.treeview.connect('revision-activated',
 
247
                self._tree_revision_activated)
 
248
 
 
249
        self.treeview.connect('tag-added', lambda w, t, r: self._update_tags())
 
250
 
 
251
        for col in ["revno", "date"]:
 
252
            option = self.config.get_user_option(col + '-column-visible')
 
253
            if option is not None:
 
254
                self.treeview.set_property(col + '-column-visible', option == 'True')
 
255
            else:
 
256
                self.treeview.set_property(col + '-column-visible', False)
 
257
 
81
258
        self.treeview.show()
82
259
 
83
 
        cell = CellRendererGraph()
84
 
        column = gtk.TreeViewColumn()
85
 
        column.set_resizable(True)
86
 
        column.pack_start(cell, expand=False)
87
 
        column.add_attribute(cell, "node", 1)
88
 
        column.add_attribute(cell, "in-lines", 2)
89
 
        column.add_attribute(cell, "out-lines", 3)
90
 
        self.treeview.append_column(column)
91
 
 
92
 
        cell = gtk.CellRendererText()
93
 
        cell.set_property("width-chars", 40)
94
 
        cell.set_property("ellipsize", pango.ELLIPSIZE_END)
95
 
        column = gtk.TreeViewColumn("Message")
96
 
        column.set_resizable(True)
97
 
        column.pack_start(cell, expand=True)
98
 
        column.add_attribute(cell, "text", 4)
99
 
        self.treeview.append_column(column)
100
 
 
101
 
        cell = gtk.CellRendererText()
102
 
        cell.set_property("width-chars", 40)
103
 
        cell.set_property("ellipsize", pango.ELLIPSIZE_END)
104
 
        column = gtk.TreeViewColumn("Committer")
105
 
        column.set_resizable(True)
106
 
        column.pack_start(cell, expand=True)
107
 
        column.add_attribute(cell, "text", 5)
108
 
        self.treeview.append_column(column)
109
 
 
110
 
        cell = gtk.CellRendererText()
111
 
        cell.set_property("ellipsize", pango.ELLIPSIZE_END)
112
 
        column = gtk.TreeViewColumn("Date")
113
 
        column.set_resizable(True)
114
 
        column.pack_start(cell, expand=True)
115
 
        column.add_attribute(cell, "text", 6)
116
 
        self.treeview.append_column(column)
117
 
 
118
 
        return scrollwin
 
260
        align = gtk.Alignment(0.0, 0.0, 1.0, 1.0)
 
261
        align.set_padding(5, 0, 0, 0)
 
262
        align.add(self.treeview)
 
263
        align.show()
 
264
 
 
265
        return align
119
266
 
120
267
    def construct_navigation(self):
121
268
        """Construct the navigation buttons."""
122
 
        frame = gtk.Frame()
123
 
        frame.set_shadow_type(gtk.SHADOW_OUT)
124
 
        frame.show()
125
 
        
126
 
        hbox = gtk.HBox(spacing=12)
127
 
        frame.add(hbox)
128
 
        hbox.show()
129
 
 
130
 
        self.back_button = gtk.Button(stock=gtk.STOCK_GO_BACK)
131
 
        self.back_button.set_relief(gtk.RELIEF_NONE)
132
 
        self.back_button.add_accelerator("clicked", self.accel_group, ord('['),
133
 
                                         0, 0)
134
 
        self.back_button.connect("clicked", self._back_clicked_cb)
135
 
        hbox.pack_start(self.back_button, expand=False, fill=True)
136
 
        self.back_button.show()
137
 
 
138
 
        self.fwd_button = gtk.Button(stock=gtk.STOCK_GO_FORWARD)
139
 
        self.fwd_button.set_relief(gtk.RELIEF_NONE)
140
 
        self.fwd_button.add_accelerator("clicked", self.accel_group, ord(']'),
141
 
                                        0, 0)
142
 
        self.fwd_button.connect("clicked", self._fwd_clicked_cb)
143
 
        hbox.pack_start(self.fwd_button, expand=False, fill=True)
144
 
        self.fwd_button.show()
145
 
 
146
 
        return frame
 
269
        self.toolbar = gtk.Toolbar()
 
270
        self.toolbar.set_style(gtk.TOOLBAR_BOTH_HORIZ)
 
271
 
 
272
        self.prev_button = self.prev_rev_action.create_tool_item()
 
273
        self.toolbar.insert(self.prev_button, -1)
 
274
 
 
275
        self.next_button = self.next_rev_action.create_tool_item()
 
276
        self.toolbar.insert(self.next_button, -1)
 
277
 
 
278
        self.toolbar.insert(gtk.SeparatorToolItem(), -1)
 
279
 
 
280
        refresh_button = gtk.ToolButton(gtk.STOCK_REFRESH)
 
281
        refresh_button.connect('clicked', self._refresh_clicked)
 
282
        self.toolbar.insert(refresh_button, -1)
 
283
 
 
284
        self.toolbar.show_all()
 
285
 
 
286
        return self.toolbar
147
287
 
148
288
    def construct_bottom(self):
149
289
        """Construct the bottom half of the window."""
150
 
        from bzrlib.plugins.gtk.logview import LogView
151
 
        self.logview = LogView()
 
290
        from bzrlib.plugins.gtk.revisionview import RevisionView
 
291
        self.revisionview = RevisionView(branch=self.branch)
152
292
        (width, height) = self.get_size()
153
 
        self.logview.set_size_request(width, int(height / 2.5))
154
 
        self.logview.show()
155
 
        self.logview.set_show_callback(self._show_clicked_cb)
156
 
        self.logview.set_go_callback(self._go_clicked_cb)
157
 
        return self.logview
158
 
 
159
 
    def set_branch(self, branch, start, maxnum):
160
 
        """Set the branch and start position for this window.
161
 
 
162
 
        Creates a new TreeModel and populates it with information about
163
 
        the new branch before updating the window title and model of the
164
 
        treeview itself.
165
 
        """
166
 
        self.branch = branch
167
 
 
168
 
        # [ revision, node, last_lines, lines, message, committer, timestamp ]
169
 
        self.model = gtk.ListStore(gobject.TYPE_PYOBJECT,
170
 
                                   gobject.TYPE_PYOBJECT,
171
 
                                   gobject.TYPE_PYOBJECT,
172
 
                                   gobject.TYPE_PYOBJECT,
173
 
                                   str, str, str)
174
 
        self.index = {}
175
 
        index = 0
176
 
 
177
 
        last_lines = []
178
 
        (self.revisions, colours, self.children, self.parent_ids,
179
 
            merge_sorted) = distances(branch, start)
180
 
        for (index, (revision, node, lines)) in enumerate(graph(
181
 
                self.revisions, colours, merge_sorted)):
182
 
            # FIXME: at this point we should be able to show the graph order
183
 
            # and lines with no message or commit data - and then incrementally
184
 
            # fill the timestamp, committer etc data as desired.
185
 
            message = revision.message.split("\n")[0]
186
 
            if revision.committer is not None:
187
 
                timestamp = format_date(revision.timestamp, revision.timezone)
188
 
            else:
189
 
                timestamp = None
190
 
            self.model.append([revision, node, last_lines, lines,
191
 
                               message, revision.committer, timestamp])
192
 
            self.index[revision] = index
193
 
            last_lines = lines
194
 
            if maxnum is not None and index > maxnum:
195
 
                break
196
 
 
197
 
        self.set_title(branch.nick + " - bzrk")
198
 
        self.treeview.set_model(self.model)
199
 
 
200
 
    def _treeview_cursor_cb(self, *args):
201
 
        """Callback for when the treeview cursor changes."""
202
 
        (path, col) = self.treeview.get_cursor()
203
 
        revision = self.model[path][0]
204
 
 
205
 
        self.back_button.set_sensitive(len(self.parent_ids[revision]) > 0)
206
 
        self.fwd_button.set_sensitive(len(self.children[revision]) > 0)
207
 
        tags = []
208
 
        if self.branch.supports_tags():
209
 
            tagdict = self.branch.tags.get_reverse_tag_dict()
210
 
            if tagdict.has_key(revision.revision_id):
211
 
                tags = tagdict[revision.revision_id]
212
 
        self.logview.set_revision(revision, tags)
 
293
        self.revisionview.set_size_request(width, int(height / 2.5))
 
294
        self.revisionview.show()
 
295
        self.revisionview.set_show_callback(self._show_clicked_cb)
 
296
        self.revisionview.connect('notify::revision', self._go_clicked_cb)
 
297
        self.treeview.connect('tag-added', lambda w, t, r: self.revisionview.update_tags())
 
298
        return self.revisionview
 
299
 
 
300
    def _tag_selected_cb(self, menuitem, revid):
 
301
        self.treeview.set_revision_id(revid)
 
302
 
 
303
    def _treeselection_changed_cb(self, selection, *args):
 
304
        """callback for when the treeview changes."""
 
305
        revision = self.treeview.get_revision()
 
306
        parents  = self.treeview.get_parents()
 
307
        children = self.treeview.get_children()
 
308
 
 
309
        if revision and revision != NULL_REVISION:
 
310
            prev_menu = gtk.Menu()
 
311
            if len(parents) > 0:
 
312
                self.prev_rev_action.set_sensitive(True)
 
313
                for parent_id in parents:
 
314
                    if parent_id and parent_id != NULL_REVISION:
 
315
                        parent = self.branch.repository.get_revision(parent_id)
 
316
                        try:
 
317
                            str = ' (' + parent.properties['branch-nick'] + ')'
 
318
                        except KeyError:
 
319
                            str = ""
 
320
 
 
321
                        item = gtk.MenuItem(parent.message.split("\n")[0] + str)
 
322
                        item.connect('activate', self._set_revision_cb, parent_id)
 
323
                        prev_menu.add(item)
 
324
                prev_menu.show_all()
 
325
            else:
 
326
                self.prev_rev_action.set_sensitive(False)
 
327
                prev_menu.hide()
 
328
 
 
329
            self.prev_button.set_menu(prev_menu)
 
330
 
 
331
            next_menu = gtk.Menu()
 
332
            if len(children) > 0:
 
333
                self.next_rev_action.set_sensitive(True)
 
334
                for child_id in children:
 
335
                    child = self.branch.repository.get_revision(child_id)
 
336
                    try:
 
337
                        str = ' (' + child.properties['branch-nick'] + ')'
 
338
                    except KeyError:
 
339
                        str = ""
 
340
 
 
341
                    item = gtk.MenuItem(child.message.split("\n")[0] + str)
 
342
                    item.connect('activate', self._set_revision_cb, child_id)
 
343
                    next_menu.add(item)
 
344
                next_menu.show_all()
 
345
            else:
 
346
                self.next_rev_action.set_sensitive(False)
 
347
                next_menu.hide()
 
348
 
 
349
            self.next_button.set_menu(next_menu)
 
350
 
 
351
            self.revisionview.set_revision(revision)
 
352
            self.revisionview.set_children(children)
 
353
    
 
354
    def _tree_revision_activated(self, widget, path, col):
 
355
        # TODO: more than one parent
 
356
        """Callback for when a treeview row gets activated."""
 
357
        revision = self.treeview.get_revision()
 
358
        parents  = self.treeview.get_parents()
 
359
 
 
360
        if len(parents) == 0:
 
361
            parent_id = None
 
362
        else:
 
363
            parent_id = parents[0]
 
364
 
 
365
        self.show_diff(revision.revision_id, parent_id)
 
366
        self.treeview.grab_focus()
 
367
        
 
368
    def _menu_diff_cb(self,w):
 
369
        (path, focus) = self.treeview.treeview.get_cursor()
 
370
        revid = self.treeview.model[path][treemodel.REVID]
 
371
        
 
372
        parentids = self.branch.repository.revision_parents(revid)
 
373
 
 
374
        if len(parentids) == 0:
 
375
            parentid = NULL_REVISION
 
376
        else:
 
377
            parentid = parentids[0]
 
378
        
 
379
        self.show_diff(revid,parentid)    
213
380
 
214
381
    def _back_clicked_cb(self, *args):
215
382
        """Callback for when the back button is clicked."""
216
 
        (path, col) = self.treeview.get_cursor()
217
 
        revision = self.model[path][0]
218
 
        if not len(self.parent_ids[revision]):
219
 
            return
220
 
 
221
 
        for parent_id in self.parent_ids[revision]:
222
 
            parent = self.revisions[parent_id]
223
 
            if same_branch(revision, parent):
224
 
                self.treeview.set_cursor(self.index[parent])
225
 
                break
226
 
        else:
227
 
            next = self.revisions[self.parent_ids[revision][0]]
228
 
            self.treeview.set_cursor(self.index[next])
229
 
        self.treeview.grab_focus()
230
 
 
 
383
        self.treeview.back()
 
384
        
231
385
    def _fwd_clicked_cb(self, *args):
232
386
        """Callback for when the forward button is clicked."""
233
 
        (path, col) = self.treeview.get_cursor()
234
 
        revision = self.model[path][0]
235
 
        if not len(self.children[revision]):
236
 
            return
237
 
 
238
 
        for child in self.children[revision]:
239
 
            if same_branch(child, revision):
240
 
                self.treeview.set_cursor(self.index[child])
241
 
                break
242
 
        else:
243
 
            prev = list(self.children[revision])[0]
244
 
            self.treeview.set_cursor(self.index[prev])
245
 
        self.treeview.grab_focus()
246
 
 
247
 
    def _go_clicked_cb(self, revid):
 
387
        self.treeview.forward()
 
388
 
 
389
    def _go_clicked_cb(self, w, p):
248
390
        """Callback for when the go button for a parent is clicked."""
249
 
        self.treeview.set_cursor(self.index[self.revisions[revid]])
 
391
        if self.revisionview.get_revision() is not None:
 
392
            self.treeview.set_revision(self.revisionview.get_revision())
 
393
 
 
394
    def _show_clicked_cb(self, revid, parentid):
 
395
        """Callback for when the show button for a parent is clicked."""
 
396
        self.show_diff(revid, parentid)
250
397
        self.treeview.grab_focus()
251
398
 
252
 
    def show_diff(self, branch, revid, parentid):
 
399
    def _compare_with_cb(self,w):
 
400
        """Callback for revision 'compare with' menu. Will show a small
 
401
            dialog with branch revisions to compare with selected revision in TreeView"""
 
402
        
 
403
        from bzrlib.plugins.gtk.revbrowser import RevisionBrowser
 
404
        
 
405
        rb = RevisionBrowser(self.branch,self)
 
406
        ret = rb.run()
 
407
        
 
408
        if ret == gtk.RESPONSE_OK:          
 
409
            (path, focus) = self.treeview.treeview.get_cursor()
 
410
            revid = self.treeview.model[path][treemodel.REVID]
 
411
            self.show_diff(revid, rb.selected_revid)
 
412
            
 
413
        rb.destroy()
 
414
            
 
415
    def _set_revision_cb(self, w, revision_id):
 
416
        self.treeview.set_revision_id(revision_id)
 
417
 
 
418
    def _brokenlines_toggled_cb(self, button):
 
419
        self.compact_view = button.get_active()
 
420
 
 
421
        if self.compact_view:
 
422
            option = 'yes'
 
423
        else:
 
424
            option = 'no'
 
425
 
 
426
        self.config.set_user_option('viz-compact-view', option)
 
427
        self.treeview.set_property('compact', self.compact_view)
 
428
        self.treeview.refresh()
 
429
 
 
430
    def _tag_revision_cb(self, w):
 
431
        try:
 
432
            self.treeview.set_sensitive(False)
 
433
            dialog = AddTagDialog(self.branch.repository, self.treeview.get_revision().revision_id, self.branch)
 
434
            response = dialog.run()
 
435
            if response != gtk.RESPONSE_NONE:
 
436
                dialog.hide()
 
437
            
 
438
                if response == gtk.RESPONSE_OK:
 
439
                    self.treeview.add_tag(dialog.tagname, dialog._revid)
 
440
                
 
441
                dialog.destroy()
 
442
 
 
443
        finally:
 
444
            self.treeview.set_sensitive(True)
 
445
 
 
446
    def _about_dialog_cb(self, w):
 
447
        from bzrlib.plugins.gtk.about import AboutDialog
 
448
 
 
449
        AboutDialog().run()
 
450
 
 
451
    def _col_visibility_changed(self, col, property):
 
452
        self.config.set_user_option(property + '-column-visible', col.get_active())
 
453
        self.treeview.set_property(property + '-column-visible', col.get_active())
 
454
 
 
455
    def _toolbar_visibility_changed(self, col):
 
456
        if col.get_active():
 
457
            self.toolbar.show() 
 
458
        else:
 
459
            self.toolbar.hide()
 
460
 
 
461
    def _show_about_cb(self, w):
 
462
        dialog = AboutDialog()
 
463
        dialog.connect('response', lambda d,r: d.destroy())
 
464
        dialog.run()
 
465
 
 
466
    def _refresh_clicked(self, w):
 
467
        self.treeview.refresh()
 
468
 
 
469
    def _update_tags(self):
 
470
        menu = gtk.Menu()
 
471
 
 
472
        if self.branch.supports_tags():
 
473
            tags = self.branch.tags.get_tag_dict().items()
 
474
            tags.sort()
 
475
            tags.reverse()
 
476
            for tag, revid in tags:
 
477
                tag_image = gtk.Image()
 
478
                tag_image.set_from_file(icon_path('tag-16.png'))
 
479
                tag_item = gtk.ImageMenuItem(tag.replace('_', '__'))
 
480
                tag_item.set_image(tag_image)
 
481
                tag_item.connect('activate', self._tag_selected_cb, revid)
 
482
                menu.add(tag_item)
 
483
            self.go_menu_tags.set_submenu(menu)
 
484
 
 
485
            self.go_menu_tags.set_sensitive(len(tags) != 0)
 
486
        else:
 
487
            self.go_menu_tags.set_sensitive(False)
 
488
 
 
489
        self.go_menu_tags.show_all()
 
490
 
 
491
    def show_diff(self, revid=None, parentid=None):
253
492
        """Open a new window to show a diff between the given revisions."""
254
493
        from bzrlib.plugins.gtk.diff import DiffWindow
255
 
        window = DiffWindow()
256
 
        (parent_tree, rev_tree) = branch.repository.revision_trees([parentid, 
257
 
                                                                   revid])
258
 
        description = revid + " - " + branch.nick
 
494
        window = DiffWindow(parent=self)
 
495
 
 
496
        if parentid is None:
 
497
            parentid = NULL_REVISION
 
498
 
 
499
        rev_tree    = self.branch.repository.revision_tree(revid)
 
500
        parent_tree = self.branch.repository.revision_tree(parentid)
 
501
 
 
502
        description = revid + " - " + self.branch.nick
259
503
        window.set_diff(description, rev_tree, parent_tree)
260
504
        window.show()
261
505
 
262
 
    def _show_clicked_cb(self, revid, parentid):
263
 
        """Callback for when the show button for a parent is clicked."""
264
 
        self.show_diff(self.branch, revid, parentid)
265
 
        self.treeview.grab_focus()
266
 
 
267
 
    def _treeview_row_mouseclick(self, widget, event):
268
 
        from bzrlib.plugins.gtk.revisionmenu import RevisionPopupMenu
269
 
        if event.button == 3:
270
 
            menu = RevisionPopupMenu(self.branch.repository, 
271
 
                [x.revision_id for x in self.selected_revisions()],
272
 
                self.branch)
273
 
            menu.popup(None, None, None, event.button, event.get_time())
274
 
 
275
 
    def selected_revision(self, path):
276
 
        return self.model[path][0]
277
 
 
278
 
    def selected_revisions(self):
279
 
        return [self.selected_revision(path) for path in \
280
 
                self.treeview.get_selection().get_selected_rows()[1]]
281
 
 
282
 
    def _treeview_row_activated_cb(self, widget, path, col):
283
 
        # TODO: more than one parent
284
 
        """Callback for when a treeview row gets activated."""
285
 
        revision = self.selected_revision(path)
286
 
        if len(self.parent_ids[revision]) == 0:
287
 
            # Ignore revisions without parent
288
 
            return
289
 
        parent_id = self.parent_ids[revision][0]
290
 
        self.show_diff(self.branch, revision.revision_id, parent_id)
291
 
        self.treeview.grab_focus()
 
506