/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 15:22:29 UTC
  • Revision ID: jelmer@samba.org-20070715152229-clmlen0vpd8d2pzx
Add docstrings, remove unused code.

Show diffs side-by-side

added added

removed removed

Lines of Context:
75
75
        self.treeview.set_search_column(4)
76
76
        self.treeview.connect("cursor-changed", self._treeview_cursor_cb)
77
77
        self.treeview.connect("row-activated", self._treeview_row_activated_cb)
78
 
        self.treeview.connect("button-release-event", 
79
 
                self._treeview_row_mouseclick)
80
78
        scrollwin.add(self.treeview)
81
79
        self.treeview.show()
82
80
 
172
170
                                   gobject.TYPE_PYOBJECT,
173
171
                                   str, str, str)
174
172
        self.index = {}
175
 
        self.set_title(branch.nick + " - bzrk")
176
 
        gobject.idle_add(self.populate_model, start, maxnum)
177
 
 
178
 
    def populate_model(self, start, maxnum):
179
173
        index = 0
180
 
        
 
174
 
181
175
        last_lines = []
182
176
        (self.revisions, colours, self.children, self.parent_ids,
183
 
            merge_sorted) = distances(self.branch.repository, start)
 
177
         merge_sorted) = distances(branch, start)
184
178
        for (index, (revision, node, lines)) in enumerate(graph(
185
179
                self.revisions, colours, merge_sorted)):
186
180
            # FIXME: at this point we should be able to show the graph order
197
191
            last_lines = lines
198
192
            if maxnum is not None and index > maxnum:
199
193
                break
 
194
 
 
195
        self.set_title(branch.nick + " - bzrk")
200
196
        self.treeview.set_model(self.model)
201
 
        return False
202
 
    
203
 
    
 
197
 
204
198
    def _treeview_cursor_cb(self, *args):
205
199
        """Callback for when the treeview cursor changes."""
206
200
        (path, col) = self.treeview.get_cursor()
208
202
 
209
203
        self.back_button.set_sensitive(len(self.parent_ids[revision]) > 0)
210
204
        self.fwd_button.set_sensitive(len(self.children[revision]) > 0)
211
 
        tags = []
212
 
        if self.branch.supports_tags():
213
 
            tagdict = self.branch.tags.get_reverse_tag_dict()
214
 
            if tagdict.has_key(revision.revision_id):
215
 
                tags = tagdict[revision.revision_id]
216
 
        self.logview.set_revision(revision, tags)
 
205
        self.logview.set_revision(revision)
217
206
 
218
207
    def _back_clicked_cb(self, *args):
219
208
        """Callback for when the back button is clicked."""
257
246
        """Open a new window to show a diff between the given revisions."""
258
247
        from bzrlib.plugins.gtk.diff import DiffWindow
259
248
        window = DiffWindow()
260
 
        (parent_tree, rev_tree) = branch.repository.revision_trees([parentid, 
261
 
                                                                   revid])
 
249
        rev_tree = branch.repository.revision_tree(revid)
 
250
        parent_tree = branch.repository.revision_tree(parentid)
262
251
        description = revid + " - " + branch.nick
263
252
        window.set_diff(description, rev_tree, parent_tree)
264
253
        window.show()
268
257
        self.show_diff(self.branch, revid, parentid)
269
258
        self.treeview.grab_focus()
270
259
 
271
 
    def _treeview_row_mouseclick(self, widget, event):
272
 
        from bzrlib.plugins.gtk.revisionmenu import RevisionPopupMenu
273
 
        if event.button == 3:
274
 
            menu = RevisionPopupMenu(self.branch.repository, 
275
 
                [x.revision_id for x in self.selected_revisions()],
276
 
                self.branch)
277
 
            menu.popup(None, None, None, event.button, event.get_time())
278
 
 
279
 
    def selected_revision(self, path):
280
 
        return self.model[path][0]
281
 
 
282
 
    def selected_revisions(self):
283
 
        return [self.selected_revision(path) for path in \
284
 
                self.treeview.get_selection().get_selected_rows()[1]]
285
 
 
286
260
    def _treeview_row_activated_cb(self, widget, path, col):
287
261
        # TODO: more than one parent
288
262
        """Callback for when a treeview row gets activated."""
289
 
        revision = self.selected_revision(path)
 
263
        revision = self.model[path][0]
290
264
        if len(self.parent_ids[revision]) == 0:
291
265
            # Ignore revisions without parent
292
266
            return