/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 olive/menu.py

  • Committer: Aaron Bentley
  • Date: 2007-01-17 06:42:55 UTC
  • mto: This revision was merged to the branch mainline in revision 129.
  • Revision ID: aaron.bentley@utoronto.ca-20070117064255-x4gznz5e0lyjq3gk
Remove usused span selector

Show diffs side-by-side

added added

removed removed

Lines of Context:
14
14
# along with this program; if not, write to the Free Software
15
15
# Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA
16
16
 
17
 
import os
18
17
import os.path
19
 
import shutil
20
18
import sys
21
19
 
22
20
try:
30
28
import bzrlib.errors as errors
31
29
from bzrlib.workingtree import WorkingTree
32
30
 
33
 
from bzrlib.plugins.gtk import _i18n
34
 
from bzrlib.plugins.gtk.dialog import error_dialog, info_dialog, question_dialog, warning_dialog
35
 
from bzrlib.plugins.gtk.errors import show_bzr_error
36
 
from bzrlib.plugins.gtk.annotate.gannotate import GAnnotateWindow
37
 
from bzrlib.plugins.gtk.annotate.config import GAnnotateConfig
38
 
from bzrlib.plugins.gtk.diff import DiffWindow
 
31
from dialog import error_dialog, info_dialog, warning_dialog
39
32
from launch import launch
40
 
from bzrlib.plugins.gtk.olive import Preferences
 
33
from olive import OlivePreferences, DiffWindow
41
34
 
42
35
class OliveMenu:
43
36
    """ This class is responsible for building the context menus. """
48
41
        self.uifile = UIFILENAME
49
42
 
50
43
        # Preferences handler
51
 
        self.pref = Preferences()
 
44
        self.pref = OlivePreferences()
52
45
        
53
46
        # Set default values
54
47
        self.path = path
60
53
        
61
54
        self.actiongroup = gtk.ActionGroup('context')
62
55
        self.actiongroup.add_actions([('add', gtk.STOCK_ADD,
63
 
                                       _i18n('Add'), None,
64
 
                                       _i18n('Add the selected file'),
 
56
                                       _('Add'), None,
 
57
                                       _('Add the selected file'),
65
58
                                       self.add_file),
66
59
                                      ('remove', gtk.STOCK_REMOVE,
67
 
                                       _i18n('Remove'), None,
68
 
                                       _i18n('Remove the selected file'),
 
60
                                       _('Remove'), None,
 
61
                                       _('Remove the selected file'),
69
62
                                       self.remove_file),
70
 
                                      ('remove_and_delete', gtk.STOCK_REMOVE,
71
 
                                       _i18n('Remove and delete'), None,
72
 
                                       _i18n('Remove the selected file/dir and delete from disk'),
73
 
                                       self.remove_and_delete_file),
74
63
                                      ('rename', None,
75
 
                                       _i18n('Rename'), None,
76
 
                                       _i18n('Rename the selected file'),
 
64
                                       _('Rename'), None,
 
65
                                       _('Rename the selected file'),
77
66
                                       self.rename_file),
78
67
                                      ('open', gtk.STOCK_OPEN,
79
 
                                       _i18n('Open'), None,
80
 
                                       _i18n('Open the selected file'),
 
68
                                       _('Open'), None,
 
69
                                       _('Open the selected file'),
81
70
                                       self.open_file),
82
 
                                      ('revert', None,
83
 
                                       _i18n('Revert'), None,
84
 
                                       _i18n('Revert the changes'),
85
 
                                       self.revert),
86
71
                                      ('commit', None,
87
 
                                       _i18n('Commit'), None,
88
 
                                       _i18n('Commit the changes'),
 
72
                                       _('Commit'), None,
 
73
                                       _('Commit the changes'),
89
74
                                       self.commit),
90
 
                                      ('annotate', None,
91
 
                                       _i18n('Annotate'), None,
92
 
                                       _i18n('Annotate the selected file'),
93
 
                                       self.annotate),
94
75
                                      ('diff', None,
95
 
                                       _i18n('Diff'), None,
96
 
                                       _i18n('Show the diff of the file'),
 
76
                                       _('Diff'), None,
 
77
                                       _('Show the diff of the file'),
97
78
                                       self.diff),
98
79
                                      ('bookmark', None,
99
 
                                       _i18n('Bookmark'), None,
100
 
                                       _i18n('Bookmark current location'),
 
80
                                       _('Bookmark'), None,
 
81
                                       _('Bookmark current location'),
101
82
                                       self.bookmark),
102
83
                                      ('edit_bookmark', gtk.STOCK_EDIT,
103
 
                                       _i18n('Edit'), None,
104
 
                                       _i18n('Edit the selected bookmark'),
 
84
                                       _('Edit'), None,
 
85
                                       _('Edit the selected bookmark'),
105
86
                                       self.edit_bookmark),
106
87
                                      ('remove_bookmark', gtk.STOCK_REMOVE,
107
 
                                       _i18n('Remove'), None,
108
 
                                       _i18n('Remove the selected bookmark'),
 
88
                                       _('Remove'), None,
 
89
                                       _('Remove the selected bookmark'),
109
90
                                       self.remove_bookmark),
110
91
                                      ('open_folder', gtk.STOCK_OPEN,
111
 
                                       _i18n('Open Folder'), None,
112
 
                                       _i18n('Open bookmark folder in Nautilus'),
 
92
                                       _('Open Folder'), None,
 
93
                                       _('Open bookmark folder in Nautilus'),
113
94
                                       self.open_folder),
114
95
                                      ('diff_selected', None,
115
 
                                       _i18n('Selected...'), None,
116
 
                                       _i18n('Show the differences of the selected file'),
 
96
                                       _('Selected...'), None,
 
97
                                       _('Show the differences of the selected file'),
117
98
                                       self.diff_selected),
118
99
                                      ('diff_all', None,
119
 
                                       _i18n('All...'), None,
120
 
                                       _i18n('Show the differences of all files'),
121
 
                                       self.diff_all),
122
 
                                      ('view_remote', None,
123
 
                                       _i18n('View contents'), None,
124
 
                                       _i18n('View the contents of the file in a builtin viewer'),
125
 
                                       self.view_remote),
126
 
                                      ('diff_remote', None,
127
 
                                       _i18n('Show differences'), None,
128
 
                                       _i18n('Show the differences between two revisions of the file'),
129
 
                                       self.diff_remote),
130
 
                                      ('revert_remote', None,
131
 
                                       _i18n('Revert to this revision'), None,
132
 
                                       _i18n('Revert the selected file to the selected revision'),
133
 
                                       self.revert_remote)
 
100
                                       _('All...'), None,
 
101
                                       _('Show the differences of all files'),
 
102
                                       self.diff_all)
134
103
                                     ])
135
104
        
136
105
        self.ui.insert_action_group(self.actiongroup, 0)
139
108
        self.cmenu_right = self.ui.get_widget('/context_right')
140
109
        self.cmenu_left = self.ui.get_widget('/context_left')
141
110
        self.toolbar_diff = self.ui.get_widget('/toolbar_diff')
142
 
        self.cmenu_remote = self.ui.get_widget('/context_remote')
143
111
        
144
112
        # Set icons
145
113
        # TODO: do it without using deprecated comm
162
130
    def left_context_menu(self):
163
131
        return self.cmenu_left
164
132
    
165
 
    def remote_context_menu(self):
166
 
        return self.cmenu_remote
167
 
    
168
 
    @show_bzr_error
169
133
    def add_file(self, action):
170
134
        """ Right context menu -> Add """
171
135
        import bzrlib.add
175
139
        filename = self.selected
176
140
            
177
141
        if filename is None:
178
 
            error_dialog(_i18n('No file was selected'),
179
 
                         _i18n('Please select a file from the list,\nor choose the other option.'))
180
 
            return
181
 
        
182
 
        bzrlib.add.smart_add([os.path.join(directory, filename)])
183
 
    
184
 
    @show_bzr_error
185
 
    def annotate(self, action):
186
 
        """ Right context menu -> Annotate """
187
 
        directory = self.path
188
 
        filename = self.selected
189
 
        
190
 
        if filename is None:
191
 
            error_dialog(_i18n('No file was selected'),
192
 
                         _i18n('Please select a file from the list.'))
193
 
            return
194
 
        
195
 
        wt, path = WorkingTree.open_containing(os.path.join(directory, filename))
196
 
        
197
 
        branch = wt.branch
198
 
        file_id = wt.path2id(wt.relpath(os.path.join(directory, filename)))
199
 
        
200
 
        window = GAnnotateWindow(all=False, plain=False, parent=self.app)
201
 
        window.set_title(os.path.join(directory, filename) + " - Annotate")
202
 
        config = GAnnotateConfig(window)
203
 
        window.show()
204
 
        branch.lock_read()
 
142
            error_dialog(_('No file was selected'),
 
143
                         _('Please select a file from the list,\nor choose the other option.'))
 
144
            return
 
145
        
205
146
        try:
206
 
            window.annotate(wt, branch, file_id)
207
 
        finally:
208
 
            branch.unlock()
 
147
            bzrlib.add.smart_add([os.path.join(directory, filename)])
 
148
        except errors.NotBranchError:
 
149
            error_dialog(_('Directory is not a branch'),
 
150
                         _('You can perform this action only in a branch.'))
 
151
            return
209
152
    
210
 
    @show_bzr_error
211
 
    def remove_file(self, action,delete_on_disk=0):
 
153
    def remove_file(self, action):
212
154
        """ Right context menu -> Remove """
213
155
        # Remove only the selected file
214
156
        directory = self.path
215
157
        filename = self.selected
216
158
        
217
159
        if filename is None:
218
 
            error_dialog(_i18n('No file was selected'),
219
 
                         _i18n('Please select a file from the list,\nor choose the other option.'))
220
 
            return
221
 
        
222
 
        wt, path = WorkingTree.open_containing(os.path.join(directory, filename))
223
 
        wt.remove(path)
224
 
        
225
 
        if delete_on_disk:
226
 
            abs_filename = os.path.join(directory,filename)
227
 
            if os.path.isdir(abs_filename):
228
 
                response = question_dialog(_i18n('Delete directory with all directories below ?'), abs_filename )
229
 
                if response == gtk.RESPONSE_YES:
230
 
                    shutil.rmtree(abs_filename)
231
 
            else:
232
 
                os.remove(abs_filename)
233
 
                
 
160
            error_dialog(_('No file was selected'),
 
161
                         _('Please select a file from the list,\nor choose the other option.'))
 
162
            return
 
163
        
 
164
        try:
 
165
            wt, path = WorkingTree.open_containing(os.path.join(directory, filename))
 
166
            wt.remove(path)
 
167
 
 
168
        except errors.NotBranchError:
 
169
            error_dialog(_('Directory is not a branch'),
 
170
                         _('You can perform this action only in a branch.'))
 
171
            return
 
172
        except errors.NotVersionedError:
 
173
            error_dialog(_('File not versioned'),
 
174
                         _('The selected file is not versioned.'))
 
175
            return
 
176
 
234
177
        self.app.set_path(self.path)
235
178
        self.app.refresh_right()
236
 
        
237
 
    def remove_and_delete_file(self, action):
238
 
        """ Right context menu -> Remove and delete"""
239
 
        self.remove_file(action,delete_on_disk=1)
240
179
 
241
180
    def rename_file(self, action):
242
181
        """ Right context menu -> Rename """
251
190
        filename = self.selected
252
191
        
253
192
        if filename is None:
254
 
            error_dialog(_i18n('No file was selected'),
255
 
                         _i18n('Please select a file from the list,\nor choose the other option.'))
 
193
            error_dialog(_('No file was selected'),
 
194
                         _('Please select a file from the list,\nor choose the other option.'))
256
195
            return
257
196
 
258
197
        if filename == '..':
267
206
            else:
268
207
                launch(fullpath) 
269
208
 
270
 
    def revert(self, action):
271
 
        """ Right context menu -> Revert """
272
 
        wt, path = WorkingTree.open_containing(self.path)
273
 
        ret = wt.revert([os.path.join(path, self.selected)])
274
 
        if ret:
275
 
            warning_dialog(_i18n('Conflicts detected'),
276
 
                           _i18n('Please have a look at the working tree before continuing.'))
277
 
        else:
278
 
            info_dialog(_i18n('Revert successful'),
279
 
                        _i18n('All files reverted to last revision.'))
280
 
        self.app.refresh_right()       
281
 
    
282
209
    def commit(self, action):
283
210
        """ Right context menu -> Commit """
284
211
        from commit import CommitDialog
288
215
            branch = wt.branch
289
216
        except NotBranchError, e:
290
217
            path = e.path
291
 
        
292
 
        if self.selected:
293
 
            selected = os.path.join(path, self.selected)
294
 
        else:
295
 
            selected = None
296
 
        commit = CommitDialog(wt=wt, selected=selected, parent=None)
297
 
        response = commit.run()
298
 
        if response != gtk.RESPONSE_NONE:
299
 
            commit.hide()
300
 
        
301
 
            if response == gtk.RESPONSE_OK:
302
 
                self.app.refresh_right()
303
 
            
304
 
            commit.destroy()
 
218
        commit = CommitDialog(wt, path, not branch)
 
219
        commit.display()
305
220
    
306
 
    @show_bzr_error
307
221
    def diff(self, action):
308
222
        """ Right context menu -> Diff """
309
 
        wt = WorkingTree.open_containing(self.path)[0]
310
 
        window = DiffWindow(self.app)
 
223
        try:
 
224
            wt = WorkingTree.open_containing(self.path)[0]
 
225
        except errors.NotBranchError:
 
226
            error_dialog(_('File is not in a branch'),
 
227
                         _('The selected file is not in a branch.'))
 
228
            return
 
229
        
 
230
        window = DiffWindow()
311
231
        parent_tree = wt.branch.repository.revision_tree(wt.branch.last_revision())
312
232
        window.set_diff(wt.branch.nick, wt, parent_tree)
313
 
        window.set_file(wt.relpath(self.path + os.sep + self.selected))
 
233
        try:
 
234
            window.set_file(wt.relpath(self.path + os.sep + self.selected))
 
235
        except errors.NoSuchFile:
 
236
            pass
314
237
        window.show()
315
238
    
316
239
    def bookmark(self, action):
317
240
        """ Right context menu -> Bookmark """
318
241
        if self.pref.add_bookmark(self.path):
319
 
            info_dialog(_i18n('Bookmark successfully added'),
320
 
                        _i18n('The current directory was bookmarked. You can reach\nit by selecting it from the left panel.'))
 
242
            info_dialog(_('Bookmark successfully added'),
 
243
                        _('The current directory was bookmarked. You can reach\nit by selecting it from the left panel.'))
321
244
            self.pref.write()
322
245
        else:
323
 
            warning_dialog(_i18n('Location already bookmarked'),
324
 
                           _i18n('The current directory is already bookmarked.\nSee the left panel for reference.'))
 
246
            warning_dialog(_('Location already bookmarked'),
 
247
                           _('The current directory is already bookmarked.\nSee the left panel for reference.'))
325
248
        
326
249
        self.app.refresh_left()
327
250
 
328
251
    def edit_bookmark(self, action):
329
252
        """ Left context menu -> Edit """
330
 
        from bookmark import BookmarkDialog
 
253
        from bookmark import OliveBookmarkDialog
331
254
        
332
255
        if self.selected != None:
333
 
            bookmark = BookmarkDialog(self.selected, self.app.window)
 
256
            bookmark = OliveBookmarkDialog(self.selected, self.app.window)
334
257
            response = bookmark.run()
335
258
            
336
259
            if response != gtk.RESPONSE_NONE:
366
289
        from diff import OliveDiff
367
290
        diff = OliveDiff(self.comm)
368
291
        diff.display()
369
 
    
370
 
    def view_remote(self, action):
371
 
        """ Remote context menu -> View contents """
372
 
        print "DEBUG: view contents."
373
 
    
374
 
    def diff_remote(self, action):
375
 
        """ Remote context menu -> Show differences """
376
 
        print "DEBUG: show differences."
377
 
    
378
 
    def revert_remote(self, action):
379
 
        """ Remote context menu -> Revert to this revision """
380
 
        print "DEBUG: revert to this revision."