/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:
14
14
import pango
15
15
 
16
16
from bzrlib.plugins.gtk.window import Window
 
17
from bzrlib.plugins.gtk import icon_path
17
18
from bzrlib.plugins.gtk.tags import AddTagDialog
18
19
from bzrlib.plugins.gtk.preferences import PreferencesWindow
19
20
from bzrlib.plugins.gtk.branchview import TreeView, treemodel
28
29
    for a particular branch.
29
30
    """
30
31
 
31
 
    def __init__(self, branch, start, maxnum, parent=None):
 
32
    def __init__(self, branch, start_revs, maxnum, parent=None):
32
33
        """Create a new BranchWindow.
33
34
 
34
35
        :param branch: Branch object for branch to show.
35
 
        :param start: Revision id of top revision.
 
36
        :param start_revs: Revision ids of top revisions.
36
37
        :param maxnum: Maximum number of revisions to display, 
37
38
                       None for no limit.
38
39
        """
41
42
        self.set_border_width(0)
42
43
 
43
44
        self.branch      = branch
44
 
        self.start       = start
 
45
        self.start_revs  = start_revs
45
46
        self.maxnum      = maxnum
46
47
        self.config      = GlobalConfig()
47
48
 
155
156
        view_menu.add(view_menu_compact)
156
157
        view_menu.add(gtk.SeparatorMenuItem())
157
158
 
158
 
        for (label, name) in [("Revision _Number", "revno"), ("_Date", "date")]:
159
 
            col = gtk.CheckMenuItem("Show " + label + " Column")
 
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")]:
160
169
            col.set_active(self.treeview.get_property(name + "-column-visible"))
161
170
            col.connect('toggled', self._col_visibility_changed, name)
162
171
            view_menu.add(col)
169
178
        go_menu_next = self.next_rev_action.create_menu_item()
170
179
        go_menu_prev = self.prev_rev_action.create_menu_item()
171
180
 
172
 
        self.go_menu_tags = gtk.MenuItem("_Tags")
 
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)
173
185
        self._update_tags()
174
186
 
175
187
        go_menu.add(go_menu_next)
183
195
 
184
196
        revision_menu_diff = gtk.MenuItem("View Changes")
185
197
        revision_menu_diff.connect('activate', 
186
 
                lambda w: self.treeview.show_diff())
 
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)
187
203
 
188
204
        revision_menu_tag = gtk.MenuItem("Tag Revision")
189
205
        revision_menu_tag.connect('activate', self._tag_revision_cb)
190
206
 
191
207
        revision_menu.add(revision_menu_tag)
192
208
        revision_menu.add(revision_menu_diff)
 
209
        revision_menu.add(revision_menu_compare)
193
210
 
194
211
        branch_menu = gtk.Menu()
195
212
        branch_menuitem = gtk.MenuItem("_Branch")
222
239
        """Construct the top-half of the window."""
223
240
        # FIXME: Make broken_line_length configurable
224
241
 
225
 
        self.treeview = TreeView(self.branch, self.start, self.maxnum, self.compact_view)
 
242
        self.treeview = TreeView(self.branch, self.start_revs, self.maxnum, self.compact_view)
226
243
 
227
244
        self.treeview.connect('revision-selected',
228
245
                self._treeselection_changed_cb)
235
252
            option = self.config.get_user_option(col + '-column-visible')
236
253
            if option is not None:
237
254
                self.treeview.set_property(col + '-column-visible', option == 'True')
 
255
            else:
 
256
                self.treeview.set_property(col + '-column-visible', False)
238
257
 
239
258
        self.treeview.show()
240
259
 
287
306
        parents  = self.treeview.get_parents()
288
307
        children = self.treeview.get_children()
289
308
 
290
 
        if revision is not None:
 
309
        if revision and revision != NULL_REVISION:
291
310
            prev_menu = gtk.Menu()
292
311
            if len(parents) > 0:
293
312
                self.prev_rev_action.set_sensitive(True)
294
313
                for parent_id in parents:
295
 
                    parent = self.branch.repository.get_revision(parent_id)
296
 
                    try:
297
 
                        str = ' (' + parent.properties['branch-nick'] + ')'
298
 
                    except KeyError:
299
 
                        str = ""
 
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 = ""
300
320
 
301
 
                    item = gtk.MenuItem(parent.message.split("\n")[0] + str)
302
 
                    item.connect('activate', self._set_revision_cb, parent_id)
303
 
                    prev_menu.add(item)
 
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)
304
324
                prev_menu.show_all()
305
325
            else:
306
326
                self.prev_rev_action.set_sensitive(False)
344
364
 
345
365
        self.show_diff(revision.revision_id, parent_id)
346
366
        self.treeview.grab_focus()
347
 
    
 
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)    
348
380
 
349
381
    def _back_clicked_cb(self, *args):
350
382
        """Callback for when the back button is clicked."""
364
396
        self.show_diff(revid, parentid)
365
397
        self.treeview.grab_focus()
366
398
 
 
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
            
367
415
    def _set_revision_cb(self, w, revision_id):
368
416
        self.treeview.set_revision_id(revision_id)
369
417
 
426
474
            tags.sort()
427
475
            tags.reverse()
428
476
            for tag, revid in tags:
429
 
                tag_item = gtk.MenuItem(tag)
 
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)
430
481
                tag_item.connect('activate', self._tag_selected_cb, revid)
431
482
                menu.add(tag_item)
432
483
            self.go_menu_tags.set_submenu(menu)