/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: Jelmer Vernooij
  • Date: 2007-07-15 18:12:57 UTC
  • Revision ID: jelmer@samba.org-20070715181257-g264qus2zyi3v39z
Add RevisionSelectionBox widget, use in TagDialog.

Show diffs side-by-side

added added

removed removed

Lines of Context:
26
26
    for a particular branch.
27
27
    """
28
28
 
29
 
    def __init__(self, app=None):
 
29
    def __init__(self):
30
30
        gtk.Window.__init__(self, gtk.WINDOW_TOPLEVEL)
31
31
        self.set_border_width(0)
32
32
        self.set_title("bzrk")
33
33
 
34
 
        self.app = app
35
 
 
36
34
        # Use three-quarters of the screen by default
37
35
        screen = self.get_screen()
38
36
        monitor = screen.get_monitor_geometry(0)
77
75
        self.treeview.set_search_column(4)
78
76
        self.treeview.connect("cursor-changed", self._treeview_cursor_cb)
79
77
        self.treeview.connect("row-activated", self._treeview_row_activated_cb)
 
78
        self.treeview.connect("button-release-event", 
 
79
                self._treeview_row_mouseclick)
80
80
        scrollwin.add(self.treeview)
81
81
        self.treeview.show()
82
82
 
149
149
        """Construct the bottom half of the window."""
150
150
        from bzrlib.plugins.gtk.logview import LogView
151
151
        self.logview = LogView()
152
 
        self.logview.set_policy(gtk.POLICY_NEVER, gtk.POLICY_AUTOMATIC)
153
 
        self.logview.set_shadow_type(gtk.SHADOW_NONE)
154
152
        (width, height) = self.get_size()
155
153
        self.logview.set_size_request(width, int(height / 2.5))
156
154
        self.logview.show()
178
176
 
179
177
        last_lines = []
180
178
        (self.revisions, colours, self.children, self.parent_ids,
181
 
         merge_sorted) = distances(branch, start)
 
179
            merge_sorted) = distances(branch, start)
182
180
        for (index, (revision, node, lines)) in enumerate(graph(
183
181
                self.revisions, colours, merge_sorted)):
184
182
            # FIXME: at this point we should be able to show the graph order
246
244
        self.treeview.set_cursor(self.index[self.revisions[revid]])
247
245
        self.treeview.grab_focus()
248
246
 
 
247
    def show_diff(self, branch, revid, parentid):
 
248
        """Open a new window to show a diff between the given revisions."""
 
249
        from bzrlib.plugins.gtk.diff import DiffWindow
 
250
        window = DiffWindow()
 
251
        (parent_tree, rev_tree) = branch.repository.revision_trees([parentid, 
 
252
                                                                   revid])
 
253
        description = revid + " - " + branch.nick
 
254
        window.set_diff(description, rev_tree, parent_tree)
 
255
        window.show()
 
256
 
249
257
    def _show_clicked_cb(self, revid, parentid):
250
258
        """Callback for when the show button for a parent is clicked."""
251
 
        if self.app is not None:
252
 
            self.app.show_diff(self.branch, revid, parentid)
 
259
        self.show_diff(self.branch, revid, parentid)
253
260
        self.treeview.grab_focus()
254
261
 
 
262
    def _treeview_row_mouseclick(self, widget, event):
 
263
        from bzrlib.plugins.gtk.revisionmenu import RevisionPopupMenu
 
264
        if event.button == 3:
 
265
            menu = RevisionPopupMenu(self.branch.repository, 
 
266
                [x.revision_id for x in self.selected_revisions()],
 
267
                self.branch)
 
268
            menu.popup(None, None, None, event.button, event.get_time())
 
269
 
 
270
    def selected_revision(self, path):
 
271
        return self.model[path][0]
 
272
 
 
273
    def selected_revisions(self):
 
274
        return [self.selected_revision(path) for path in \
 
275
                self.treeview.get_selection().get_selected_rows()[1]]
 
276
 
255
277
    def _treeview_row_activated_cb(self, widget, path, col):
256
278
        # TODO: more than one parent
257
279
        """Callback for when a treeview row gets activated."""
258
 
        revision = self.model[path][0]
 
280
        revision = self.selected_revision(path)
259
281
        if len(self.parent_ids[revision]) == 0:
260
282
            # Ignore revisions without parent
261
283
            return
262
284
        parent_id = self.parent_ids[revision][0]
263
 
        if self.app is not None:
264
 
            self.app.show_diff(self.branch, revision.revision_id, parent_id)
 
285
        self.show_diff(self.branch, revision.revision_id, parent_id)
265
286
        self.treeview.grab_focus()