/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: Jelmer Vernooij
  • Date: 2006-09-30 10:21:43 UTC
  • Revision ID: jelmer@samba.org-20060930102143-c0ef64d6ca860c21
Merge some files from Olive and bzr-gtk.

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:
26
24
    pass
27
25
 
28
26
import gtk
29
 
from dialog import question_dialog
30
27
 
31
28
import bzrlib.errors as errors
32
29
from bzrlib.workingtree import WorkingTree
33
30
 
34
 
from bzrlib.plugins.gtk.dialog import error_dialog, info_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 olive import Preferences
 
33
from olive import OlivePreferences
41
34
 
42
35
class OliveMenu:
43
36
    """ This class is responsible for building the context menus. """
44
 
    def __init__(self, path, selected, app=None):
 
37
    def __init__(self, path, selected):
45
38
        # Load the UI file
46
 
        from guifiles import UIFILENAME
47
 
 
48
 
        self.uifile = UIFILENAME
49
 
 
 
39
        if sys.platform == 'win32':
 
40
            self.uifile = os.path.dirname(sys.executable) + "/share/olive/cmenu.ui"
 
41
        else:
 
42
            self.uifile = "/usr/share/olive/cmenu.ui"
 
43
        
 
44
        if not os.path.exists(self.uifile):
 
45
            # Load from current directory if not installed
 
46
            self.uifile = "cmenu.ui"
 
47
            # Check again
 
48
            if not os.path.exists(self.uifile):
 
49
                # Fail
 
50
                print _('UI description file cannot be found.')
 
51
                sys.exit(1)
 
52
        
50
53
        # Preferences handler
51
 
        self.pref = Preferences()
 
54
        self.pref = OlivePreferences()
52
55
        
53
56
        # Set default values
54
57
        self.path = path
55
58
        self.selected = selected
56
 
        self.app = app
 
59
        print "DEBUG: path =", self.path
 
60
        print "DEBUG: selected =", self.selected
57
61
        
58
62
        # Create the file list context menu
59
63
        self.ui = gtk.UIManager()
67
71
                                       _('Remove'), None,
68
72
                                       _('Remove the selected file'),
69
73
                                       self.remove_file),
70
 
                                      ('remove_and_delete', gtk.STOCK_REMOVE,
71
 
                                       _('Remove and delete'), None,
72
 
                                       _('Remove the selected file/dir and delete from disk'),
73
 
                                       self.remove_and_delete_file),
74
 
                                      ('rename', None,
75
 
                                       _('Rename'), None,
76
 
                                       _('Rename the selected file'),
77
 
                                       self.rename_file),
78
74
                                      ('open', gtk.STOCK_OPEN,
79
75
                                       _('Open'), None,
80
76
                                       _('Open the selected file'),
81
77
                                       self.open_file),
82
 
                                      ('revert', None,
83
 
                                       _('Revert'), None,
84
 
                                       _('Revert the changes'),
85
 
                                       self.revert),
86
78
                                      ('commit', None,
87
79
                                       _('Commit'), None,
88
80
                                       _('Commit the changes'),
89
81
                                       self.commit),
90
 
                                      ('annotate', None,
91
 
                                       _('Annotate'), None,
92
 
                                       _('Annotate the selected file'),
93
 
                                       self.annotate),
94
82
                                      ('diff', None,
95
83
                                       _('Diff'), None,
96
84
                                       _('Show the diff of the file'),
118
106
                                      ('diff_all', None,
119
107
                                       _('All...'), None,
120
108
                                       _('Show the differences of all files'),
121
 
                                       self.diff_all),
122
 
                                      ('view_remote', None,
123
 
                                       _('View contents'), None,
124
 
                                       _('View the contents of the file in a builtin viewer'),
125
 
                                       self.view_remote),
126
 
                                      ('diff_remote', None,
127
 
                                       _('Show differences'), None,
128
 
                                       _('Show the differences between two revisions of the file'),
129
 
                                       self.diff_remote),
130
 
                                      ('revert_remote', None,
131
 
                                       _('Revert to this revision'), None,
132
 
                                       _('Revert the selected file to the selected revision'),
133
 
                                       self.revert_remote)
 
109
                                       self.diff_all)
134
110
                                     ])
135
111
        
136
112
        self.ui.insert_action_group(self.actiongroup, 0)
139
115
        self.cmenu_right = self.ui.get_widget('/context_right')
140
116
        self.cmenu_left = self.ui.get_widget('/context_left')
141
117
        self.toolbar_diff = self.ui.get_widget('/toolbar_diff')
142
 
        self.cmenu_remote = self.ui.get_widget('/context_remote')
143
118
        
144
119
        # Set icons
145
120
        # TODO: do it without using deprecated comm
162
137
    def left_context_menu(self):
163
138
        return self.cmenu_left
164
139
    
165
 
    def remote_context_menu(self):
166
 
        return self.cmenu_remote
167
 
    
168
 
    @show_bzr_error
169
140
    def add_file(self, action):
170
141
        """ Right context menu -> Add """
171
142
        import bzrlib.add
179
150
                         _('Please select a file from the list,\nor choose the other option.'))
180
151
            return
181
152
        
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(_('No file was selected'),
192
 
                         _('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)
201
 
        window.set_title(os.path.join(directory, filename) + " - Annotate")
202
 
        config = GAnnotateConfig(window)
203
 
        window.show()
204
 
        branch.lock_read()
205
153
        try:
206
 
            window.annotate(wt, branch, file_id)
207
 
        finally:
208
 
            branch.unlock()
 
154
            bzrlib.add.smart_add([directory + '/' + filename])
 
155
        except errors.NotBranchError:
 
156
            error_dialog(_('Directory is not a branch'),
 
157
                         _('You can perform this action only in a branch.'))
 
158
            return
209
159
    
210
 
    @show_bzr_error
211
 
    def remove_file(self, action,delete_on_disk=0):
 
160
    def remove_file(self, action):
212
161
        """ Right context menu -> Remove """
213
162
        # Remove only the selected file
214
163
        directory = self.path
219
168
                         _('Please select a file from the list,\nor choose the other option.'))
220
169
            return
221
170
        
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(_('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
 
                
234
 
        self.app.set_path(self.path)
235
 
        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
 
 
241
 
    def rename_file(self, action):
242
 
        """ Right context menu -> Rename """
243
 
        from rename import OliveRename
244
 
        wt = WorkingTree.open_containing(self.path + os.sep + self.selected)[0]
245
 
        rename = OliveRename(wt, wt.relpath(self.path), self.selected)
246
 
        rename.display()
247
 
    
 
171
        try:
 
172
            wt, path = WorkingTree.open_containing(directory + os.sep + filename)
 
173
            wt.remove(path)
 
174
 
 
175
        except errors.NotBranchError:
 
176
            error_dialog(_('Directory is not a branch'),
 
177
                         _('You can perform this action only in a branch.'))
 
178
            return
 
179
        except errors.NotVersionedError:
 
180
            error_dialog(_('File not versioned'),
 
181
                         _('The selected file is not versioned.'))
 
182
            return
 
183
 
248
184
    def open_file(self, action):
249
185
        """ Right context menu -> Open """
250
186
        # Open only the selected file
267
203
            else:
268
204
                launch(fullpath) 
269
205
 
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(_('Conflicts detected'),
276
 
                           _('Please have a look at the working tree before continuing.'))
277
 
        else:
278
 
            info_dialog(_('Revert successful'),
279
 
                        _('All files reverted to last revision.'))
280
 
        self.app.refresh_right()       
281
 
    
282
206
    def commit(self, action):
283
207
        """ Right context menu -> Commit """
284
 
        from commit import CommitDialog
285
 
        branch = None
286
 
        try:
287
 
            wt, path = WorkingTree.open_containing(self.path)
288
 
            branch = wt.branch
289
 
        except NotBranchError, e:
290
 
            path = e.path
291
 
        
292
 
        commit = CommitDialog(wt, path, not branch, self.selected)
293
 
        response = commit.run()
294
 
        if response != gtk.RESPONSE_NONE:
295
 
            commit.hide()
296
 
        
297
 
            if response == gtk.RESPONSE_OK:
298
 
                self.app.refresh_right()
299
 
            
300
 
            commit.destroy()
 
208
        from commit import OliveCommit
 
209
        wt, path = WorkingTree.open_containing(self.path)
 
210
        commit = OliveCommit(wt, path)
 
211
        commit.display()
301
212
    
302
 
    @show_bzr_error
303
213
    def diff(self, action):
304
214
        """ Right context menu -> Diff """
305
 
        wt = WorkingTree.open_containing(self.path)[0]
306
 
        window = DiffWindow()
307
 
        parent_tree = wt.branch.repository.revision_tree(wt.branch.last_revision())
308
 
        window.set_diff(wt.branch.nick, wt, parent_tree)
309
 
        window.set_file(wt.relpath(self.path + os.sep + self.selected))
310
 
        window.show()
 
215
        from diff import OliveDiff
 
216
        diff = OliveDiff(self.comm)
 
217
        diff.display()
311
218
    
312
219
    def bookmark(self, action):
313
220
        """ Right context menu -> Bookmark """
314
 
        if self.pref.add_bookmark(self.path):
 
221
        if self.pref.add_bookmark(self.comm.get_path()):
315
222
            info_dialog(_('Bookmark successfully added'),
316
223
                        _('The current directory was bookmarked. You can reach\nit by selecting it from the left panel.'))
317
 
            self.pref.write()
318
224
        else:
319
225
            warning_dialog(_('Location already bookmarked'),
320
226
                           _('The current directory is already bookmarked.\nSee the left panel for reference.'))
321
 
        
322
 
        self.app.refresh_left()
323
227
 
324
228
    def edit_bookmark(self, action):
325
229
        """ Left context menu -> Edit """
326
 
        from bookmark import BookmarkDialog
327
 
        
 
230
        from bookmark import OliveBookmark
 
231
 
328
232
        if self.selected != None:
329
 
            bookmark = BookmarkDialog(self.selected, self.app.window)
330
 
            response = bookmark.run()
331
 
            
332
 
            if response != gtk.RESPONSE_NONE:
333
 
                bookmark.hide()
334
 
        
335
 
                if response == gtk.RESPONSE_OK:
336
 
                    self.app.refresh_left()
337
 
            
338
 
                bookmark.destroy()
 
233
            bookmark = OliveBookmark(self.selected)
 
234
            bookmark.display()
339
235
 
340
236
    def remove_bookmark(self, action):
341
237
        """ Left context menu -> Remove """
342
238
        
343
239
        if self.selected != None:
344
 
            self.pref.remove_bookmark(self.selected)
345
 
            self.pref.write()
346
 
        
347
 
        self.app.refresh_left()
 
240
            self.pref.remove_bookmark(self.comm.get_selected_left())
 
241
            self.comm.refresh_left()
348
242
    
349
243
    def open_folder(self, action):
350
244
        """ Left context menu -> Open Folder """
362
256
        from diff import OliveDiff
363
257
        diff = OliveDiff(self.comm)
364
258
        diff.display()
365
 
    
366
 
    def view_remote(self, action):
367
 
        """ Remote context menu -> View contents """
368
 
        print "DEBUG: view contents."
369
 
    
370
 
    def diff_remote(self, action):
371
 
        """ Remote context menu -> Show differences """
372
 
        print "DEBUG: show differences."
373
 
    
374
 
    def revert_remote(self, action):
375
 
        """ Remote context menu -> Revert to this revision """
376
 
        print "DEBUG: revert to this revision."