Kiln » TortoiseHg » TortoiseHg
Clone URL:  
Pushed to one repository · View In Graph Contained in 1.0, 1.0.1, and 1.0.2

add bookmark dialog

Addresses #498

Changeset 4d7fd3e1f230

Parent f92edba5cf8c

by Emmanuel Rosa

Changes to 3 files · Browse files at 4d7fd3e1f230 Showing diff from parent f92edba5cf8c Diff from another changeset...

Change 1 of 1 Show Entire File tortoisehg/​hgtk/​bookmarkadd.py Stacked
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
@@ -0,0 +1,160 @@
+# bookmarkadd.py - TortoiseHg dialog to add bookmark +# +# Copyright 2007 TK Soh <teekaysoh@gmail.com> +# Copyright 2007 Steve Borho <steve@borho.org> +# Copyright 2009 Emmanuel Rosa <goaway1000@gmail.com> +# +# This software may be used and distributed according to the terms of the +# GNU General Public License version 2, incorporated herein by reference. + +import os +import gtk +import traceback + +from mercurial import hg, ui, util +from hgext import bookmarks + +from tortoisehg.util.i18n import _ +from tortoisehg.util import hglib, i18n + +from tortoisehg.hgtk import dialog, gtklib + +keep = i18n.keepgettext() + +class BookmarkAddDialog(gtk.Dialog): + """ Dialog to add bookmark to Mercurial repo """ + def __init__(self, repo, bookmark='', rev=''): + """ Initialize the Dialog """ + gtk.Dialog.__init__(self, + buttons=(gtk.STOCK_CLOSE, gtk.RESPONSE_CLOSE)) + gtklib.set_tortoise_keys(self) + self.set_title(_('Bookmark - %s') % hglib.get_reponame(repo)) + self.set_resizable(False) + self.set_has_separator(False) + self.connect('response', self.dialog_response) + + self.repo = repo + + # add Add button + addbutton = gtk.Button(_('Add')) + addbutton.connect('clicked', lambda b: self._do_add_bookmark()) + self.action_area.pack_end(addbutton) + + # add Remove button + removebutton = gtk.Button(_('Remove')) + removebutton.connect('clicked', lambda b: self._do_rm_bookmark()) + self.action_area.pack_end(removebutton) + + # top layout table + table = gtklib.LayoutTable() + self.vbox.pack_start(table, True, True, 2) + + ## bookmark name input + self._bookmarkslist = gtk.ListStore(str) + self._bookmarklistbox = gtk.ComboBoxEntry(self._bookmarkslist, 0) + self._bookmark_input = self._bookmarklistbox.get_child() + self._bookmark_input.connect('activate', self._bookmarkinput_activated) + self._bookmark_input.set_text(bookmark) + table.add_row(_('Bookmark:'), self._bookmarklistbox, padding=False) + + ## revision input + self._rev_input = gtk.Entry() + self._rev_input.set_width_chars(12) + self._rev_input.set_text(rev) + table.add_row(_('Revision:'), self._rev_input) + + # prepare to show + self._refresh() + self._bookmarklistbox.grab_focus() + + def _refresh(self): + """ update display on dialog with recent repo data """ + self.repo.invalidate() + self._bookmarkslist.clear() + self._bookmark_input.set_text("") + + # add bookmarks to drop-down list + bookmarks = hglib.get_repo_bookmarks(self.repo) + bookmarks.sort() + for bookmarkname in bookmarks: + if bookmarkname == "tip": + continue + self._bookmarkslist.append([bookmarkname]) + + def dialog_response(self, dialog, response_id): + if response_id == gtk.RESPONSE_CLOSE \ + or response_id == gtk.RESPONSE_DELETE_EVENT: + self.destroy() + + def _bookmarkinput_activated(self, bookmarkinput): + self._do_add_bookmark() + + def _do_add_bookmark(self): + # gather input data + name = self._bookmark_input.get_text() + rev = self._rev_input.get_text() + + # verify input + if name == '': + dialog.error_dialog(self, _('Bookmark input is empty'), + _('Please enter bookmark name')) + self._bookmark_input.grab_focus() + return False + + # add bookmark to repo + try: + self._add_hg_bookmark(name, rev) + dialog.info_dialog(self, _('Bookmarking completed'), + _('Bookmark "%s" has been added') % name) + self._refresh() + except util.Abort, inst: + dialog.error_dialog(self, _('Error in bookmarking'), str(inst)) + return False + except: + dialog.error_dialog(self, _('Error in bookmarking'), + traceback.format_exc()) + return False + + def _do_rm_bookmark(self): + # gather input data + name = self._bookmark_input.get_text() + + # verify input + if name == '': + dialog.error_dialog(self, _('Bookmark name is empty'), + _('Please select bookmark name to remove')) + self._bookmark_input.grab_focus() + return False + + try: + self._rm_hg_bookmark(name) + dialog.info_dialog(self, _('Bookmarking completed'), + _('Bookmark "%s" has been removed') % name) + self._refresh() + except util.Abort, inst: + dialog.error_dialog(self, _('Error in bookmarking'), str(inst)) + return False + except: + dialog.error_dialog(self, _('Error in bookmarking'), + traceback.format_exc()) + return False + + def _add_hg_bookmark(self, name, revision): + if name in hglib.get_repo_bookmarks(self.repo): + raise util.Abort(_('a bookmark named "%s" already exists') % name) + + ctx = self.repo[revision] + r = ctx.node() + bookmarks.bookmark(ui=ui.ui(), + repo=self.repo, + rev=revision, + mark=name) + + def _rm_hg_bookmark(self, name): + if not name in hglib.get_repo_bookmarks(self.repo): + raise util.Abort(_("Bookmark '%s' does not exist") % name) + + bookmarks.bookmark(ui=ui.ui(), + repo=self.repo, + mark=name, + delete=True)
 
25
26
27
28
 
29
30
31
 
719
720
721
 
722
723
724
 
1108
1109
1110
 
 
 
 
 
 
 
 
 
1111
1112
1113
 
1705
1706
1707
1708
1709
1710
1711
1712
1713
1714
1715
 
1716
1717
1718
1719
1720
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
1721
1722
1723
 
25
26
27
 
28
29
30
31
 
719
720
721
722
723
724
725
 
1109
1110
1111
1112
1113
1114
1115
1116
1117
1118
1119
1120
1121
1122
1123
 
1715
1716
1717
 
 
 
 
 
 
 
 
1718
1719
1720
1721
1722
1723
1724
1725
1726
1727
1728
1729
1730
1731
1732
1733
1734
1735
1736
1737
1738
1739
1740
1741
@@ -25,7 +25,7 @@
 from tortoisehg.hgtk import gdialog, gtklib, hgcmd, gorev, thgstrip  from tortoisehg.hgtk import backout, status, hgemail, tagadd, update, merge  from tortoisehg.hgtk import archive, changeset, thgconfig, thgmq, histdetails -from tortoisehg.hgtk import statusbar +from tortoisehg.hgtk import statusbar, bookmarkadd    def create_menu(label, callback):   menuitem = gtk.MenuItem(label, True) @@ -719,6 +719,7 @@
  m.append(create_menu(_('_Bundle rev:tip...'), self.bundle_rev_to_tip))   m.append_sep()   m.append(create_menu(_('Add/Remove _Tag...'), self.add_tag)) + m.append(create_menu(_('Add/Remove B_ookmark...'), self.add_bookmark))   cmenu_backout = create_menu(_('Backout Revision...'), self.backout_rev)   m.append(cmenu_backout)   m.append(create_menu(_('_Revert'), self.revert)) @@ -1108,6 +1109,15 @@
  def get_extras(self):   return self.stbar   + def refresh_on_marker_change(self, oldlen, oldmarkers, newmarkers): + self.repo.invalidate() + self.changeview.clear_cache() + if len(self.repo) != oldlen: + self.reload_log() + else: + if newmarkers != oldmarkers: + self.refresh_model() +   def apply_clicked(self, button):   combo = self.ppullcombo   list, iter = combo.get_model(), combo.get_active_iter() @@ -1705,19 +1715,27 @@
  rev = self.currevid     def refresh(*args): - self.repo.invalidate() - self.changeview.clear_cache() - if len(self.repo) != oldlen: - self.reload_log() - else: - newtags = self.repo.tagslist() - if newtags != oldtags: - self.refresh_model() + self.refresh_on_marker_change(oldlen, oldtags, self.repo.tagslist())     dialog = tagadd.TagAddDialog(self.repo, rev=str(rev))   dialog.connect('destroy', refresh)   self.show_dialog(dialog)   + def add_bookmark(self, menuitem): + # save bookmark info for detecting new bookmarks added + oldbookmarks = hglib.get_repo_bookmarks(self.repo) + oldlen = len(self.repo) + rev = self.currevid + + def refresh(*args): + self.refresh_on_marker_change(oldlen, + oldbookmarks, + hglib.get_repo_bookmarks(self.repo)) + + dialog = bookmarkadd.BookmarkAddDialog(self.repo, rev=str(rev)) + dialog.connect('destroy', refresh) + self.show_dialog(dialog) +   def show_status(self, menuitem):   rev = self.currevid   statopts = self.merge_opts(commands.table['^status|st'][1],
 
236
237
238
 
 
 
236
237
238
239
240
@@ -236,3 +236,5 @@
  return_path = path_aux   return return_path   +def get_repo_bookmarks(repo): + return repo._bookmarks.keys()