/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: 2008-07-17 11:51:03 UTC
  • Revision ID: jelmer@samba.org-20080717115103-djh5sb0pvpse2zkb
Add note about glade.

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
17
18
import os.path
 
19
import shutil
18
20
import sys
19
21
 
20
22
try:
22
24
    pygtk.require("2.0")
23
25
except:
24
26
    pass
25
 
try:
26
 
    import gtk
27
 
    import gtk.glade
28
 
except:
29
 
    sys.exit(1)
30
 
 
31
 
import olive.backend.fileops as fileops
32
 
import olive.backend.errors as errors
 
27
 
 
28
import gtk
 
29
 
 
30
import bzrlib.errors as errors
 
31
from bzrlib.workingtree import WorkingTree
 
32
 
 
33
from bzrlib.plugins.gtk import _i18n, launch
 
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
 
39
from bzrlib.plugins.gtk.olive import Preferences
33
40
 
34
41
class OliveMenu:
35
42
    """ This class is responsible for building the context menus. """
36
 
    def __init__(self, gladefile, comm, dialog):
 
43
    def __init__(self, path, selected, app=None):
37
44
        # Load the UI file
38
 
        if sys.platform == 'win32':
39
 
            self.uifile = os.path.dirname(sys.executable) + "/share/olive/cmenu.ui"
40
 
        else:
41
 
            self.uifile = "/usr/share/olive/cmenu.ui"
42
 
        
43
 
        if not os.path.exists(self.uifile):
44
 
            # Load from current directory if not installed
45
 
            self.uifile = "cmenu.ui"
46
 
            # Check again
47
 
            if not os.path.exists(self.uifile):
48
 
                # Fail
49
 
                print _('UI description file cannot be found.')
50
 
                sys.exit(1)
51
 
        
52
 
        self.gladefile = gladefile
53
 
        self.comm = comm
54
 
        self.dialog = dialog
 
45
        from guifiles import UIFILENAME
 
46
 
 
47
        self.uifile = UIFILENAME
 
48
 
 
49
        # Preferences handler
 
50
        self.pref = Preferences()
 
51
        
 
52
        # Set default values
 
53
        self.path = path
 
54
        self.selected = selected
 
55
        self.app = app
55
56
        
56
57
        # Create the file list context menu
57
58
        self.ui = gtk.UIManager()
58
59
        
59
60
        self.actiongroup = gtk.ActionGroup('context')
60
61
        self.actiongroup.add_actions([('add', gtk.STOCK_ADD,
61
 
                                       _('Add'), None,
62
 
                                       _('Add the selected file'),
 
62
                                       _i18n('Add'), None,
 
63
                                       _i18n('Add the selected file'),
63
64
                                       self.add_file),
64
65
                                      ('remove', gtk.STOCK_REMOVE,
65
 
                                       _('Remove'), None,
66
 
                                       _('Remove the selected file'),
 
66
                                       _i18n('Remove'), None,
 
67
                                       _i18n('Remove the selected file'),
67
68
                                       self.remove_file),
 
69
                                      ('remove_and_delete', gtk.STOCK_REMOVE,
 
70
                                       _i18n('Remove and delete'), None,
 
71
                                       _i18n('Remove the selected file/dir and delete from disk'),
 
72
                                       self.remove_and_delete_file),
 
73
                                      ('rename', None,
 
74
                                       _i18n('Rename'), None,
 
75
                                       _i18n('Rename the selected file'),
 
76
                                       self.rename_file),
 
77
                                      ('open', gtk.STOCK_OPEN,
 
78
                                       _i18n('Open'), None,
 
79
                                       _i18n('Open the selected file'),
 
80
                                       self.open_file),
 
81
                                      ('revert', None,
 
82
                                       _i18n('Revert'), None,
 
83
                                       _i18n('Revert the changes'),
 
84
                                       self.revert),
68
85
                                      ('commit', None,
69
 
                                       _('Commit'), None,
70
 
                                       _('Commit the changes'),
 
86
                                       _i18n('Commit'), None,
 
87
                                       _i18n('Commit the changes'),
71
88
                                       self.commit),
 
89
                                      ('annotate', None,
 
90
                                       _i18n('Annotate'), None,
 
91
                                       _i18n('Annotate the selected file'),
 
92
                                       self.annotate),
72
93
                                      ('diff', None,
73
 
                                       _('Diff'), None,
74
 
                                       _('Show the diff of the file'),
 
94
                                       _i18n('Diff'), None,
 
95
                                       _i18n('Show the diff of the file'),
75
96
                                       self.diff),
76
97
                                      ('bookmark', None,
77
 
                                       _('Bookmark'), None,
78
 
                                       _('Bookmark current location'),
 
98
                                       _i18n('Bookmark'), None,
 
99
                                       _i18n('Bookmark current location'),
79
100
                                       self.bookmark),
 
101
                                      ('edit_bookmark', gtk.STOCK_EDIT,
 
102
                                       _i18n('Edit'), None,
 
103
                                       _i18n('Edit the selected bookmark'),
 
104
                                       self.edit_bookmark),
80
105
                                      ('remove_bookmark', gtk.STOCK_REMOVE,
81
 
                                       _('Remove'), None,
82
 
                                       _('Remove the selected bookmark'),
 
106
                                       _i18n('Remove'), None,
 
107
                                       _i18n('Remove the selected bookmark'),
83
108
                                       self.remove_bookmark),
 
109
                                      ('open_folder', gtk.STOCK_OPEN,
 
110
                                       _i18n('Open Folder'), None,
 
111
                                       _i18n('Open bookmark folder in Nautilus'),
 
112
                                       self.open_folder),
84
113
                                      ('diff_selected', None,
85
 
                                       _('Selected...'), None,
86
 
                                       _('Show the differences of the selected file'),
 
114
                                       _i18n('Selected...'), None,
 
115
                                       _i18n('Show the differences of the selected file'),
87
116
                                       self.diff_selected),
88
117
                                      ('diff_all', None,
89
 
                                       _('All...'), None,
90
 
                                       _('Show the differences of all files'),
91
 
                                       self.diff_all)
 
118
                                       _i18n('All...'), None,
 
119
                                       _i18n('Show the differences of all files'),
 
120
                                       self.diff_all),
 
121
                                      ('view_remote', None,
 
122
                                       _i18n('View contents'), None,
 
123
                                       _i18n('View the contents of the file in a builtin viewer'),
 
124
                                       self.view_remote),
 
125
                                      ('diff_remote', None,
 
126
                                       _i18n('Show differences'), None,
 
127
                                       _i18n('Show the differences between two revisions of the file'),
 
128
                                       self.diff_remote),
 
129
                                      ('revert_remote', None,
 
130
                                       _i18n('Revert to this revision'), None,
 
131
                                       _i18n('Revert the selected file to the selected revision'),
 
132
                                       self.revert_remote)
92
133
                                     ])
93
134
        
94
135
        self.ui.insert_action_group(self.actiongroup, 0)
97
138
        self.cmenu_right = self.ui.get_widget('/context_right')
98
139
        self.cmenu_left = self.ui.get_widget('/context_left')
99
140
        self.toolbar_diff = self.ui.get_widget('/toolbar_diff')
 
141
        self.cmenu_remote = self.ui.get_widget('/context_remote')
100
142
        
101
143
        # Set icons
102
 
        commit_menu = self.ui.get_widget('/context_right/commit')
103
 
        commit_image = self.comm.menuitem_branch_commit.get_image()
104
 
        commit_pixbuf = commit_image.get_pixbuf()
105
 
        commit_icon = gtk.Image()
106
 
        commit_icon.set_from_pixbuf(commit_pixbuf)
107
 
        commit_menu.set_image(commit_icon)
108
 
        diff_menu = self.ui.get_widget('/context_right/diff')
109
 
        diff_image = self.comm.menuitem_stats_diff.get_image()
110
 
        diff_pixbuf = diff_image.get_pixbuf()
111
 
        diff_icon = gtk.Image()
112
 
        diff_icon.set_from_pixbuf(diff_pixbuf)
113
 
        diff_menu.set_image(diff_icon)
 
144
        # TODO: do it without using deprecated comm
 
145
        #commit_menu = self.ui.get_widget('/context_right/commit')
 
146
        #commit_image = self.comm.menuitem_branch_commit.get_image()
 
147
        #commit_pixbuf = commit_image.get_pixbuf()
 
148
        #commit_icon = gtk.Image()
 
149
        #commit_icon.set_from_pixbuf(commit_pixbuf)
 
150
        #commit_menu.set_image(commit_icon)
 
151
        #diff_menu = self.ui.get_widget('/context_right/diff')
 
152
        #diff_image = self.comm.menuitem_stats_diff.get_image()
 
153
        #diff_pixbuf = diff_image.get_pixbuf()
 
154
        #diff_icon = gtk.Image()
 
155
        #diff_icon.set_from_pixbuf(diff_pixbuf)
 
156
        #diff_menu.set_image(diff_icon)
114
157
 
115
158
    def right_context_menu(self):
116
159
        return self.cmenu_right
118
161
    def left_context_menu(self):
119
162
        return self.cmenu_left
120
163
    
 
164
    def remote_context_menu(self):
 
165
        return self.cmenu_remote
 
166
    
 
167
    @show_bzr_error
121
168
    def add_file(self, action):
122
169
        """ Right context menu -> Add """
 
170
        import bzrlib.add
 
171
        
123
172
        # Add only the selected file
124
 
        directory = self.comm.get_path()
125
 
        filename = self.comm.get_selected_right()
 
173
        directory = self.path
 
174
        filename = self.selected
126
175
            
127
176
        if filename is None:
128
 
            self.dialog.error_dialog(_('No file was selected'),
129
 
                                     _('Please select a file from the list,\nor choose the other option.'))
130
 
            return
131
 
        
 
177
            error_dialog(_i18n('No file was selected'),
 
178
                         _i18n('Please select a file from the list,\nor choose the other option.'))
 
179
            return
 
180
        
 
181
        wt, path = WorkingTree.open_containing(os.path.join(directory, filename))
 
182
        wt.add([path])
 
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()
132
205
        try:
133
 
            fileops.add([directory + '/' + filename])
134
 
        except errors.NotBranchError:
135
 
            self.dialog.error_dialog(_('Directory is not a branch'),
136
 
                                     _('You can perform this action only in a branch.'))
137
 
            return
138
 
        except:
139
 
            raise
140
 
        
141
 
        self.comm.refresh_right()
 
206
            window.annotate(wt, branch, file_id)
 
207
        finally:
 
208
            branch.unlock()
142
209
    
143
 
    def remove_file(self, action):
 
210
    @show_bzr_error
 
211
    def remove_file(self, action,delete_on_disk=0):
144
212
        """ Right context menu -> Remove """
145
213
        # Remove only the selected file
146
 
        directory = self.comm.get_path()
147
 
        filename = self.comm.get_selected_right()
148
 
        
149
 
        if filename is None:
150
 
            self.dialog.error_dialog(_('No file was selected'),
151
 
                                     _('Please select a file from the list,\nor choose the other option.'))
152
 
            return
153
 
        
154
 
        try:
155
 
            fileops.remove([directory + '/' + filename])
156
 
        except errors.NotBranchError:
157
 
            self.dialog.error_dialog(_('Directory is not a branch'),
158
 
                                     _('You can perform this action only in a branch.'))
159
 
            return
160
 
        except errors.NotVersionedError:
161
 
            self.dialog.error_dialog(_('File not versioned'),
162
 
                                     _('The selected file is not versioned.'))
163
 
            return
164
 
        except:
165
 
            raise
166
 
        
167
 
        self.comm.refresh_right()
168
 
 
 
214
        directory = self.path
 
215
        filename = self.selected
 
216
        
 
217
        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
                
 
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
    
 
248
    def open_file(self, action):
 
249
        """ Right context menu -> Open """
 
250
        # Open only the selected file
 
251
        filename = self.selected
 
252
        
 
253
        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.'))
 
256
            return
 
257
 
 
258
        if filename == '..':
 
259
            # TODO: how to enter a directory?
 
260
            return
 
261
        else:
 
262
            fullpath = self.path + os.sep + filename
 
263
            if os.path.isdir(fullpath):
 
264
                # selected item is an existant directory
 
265
                # TODO: how to enter a directory?
 
266
                return
 
267
            else:
 
268
                launch(fullpath) 
 
269
 
 
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
    
169
282
    def commit(self, action):
170
283
        """ Right context menu -> Commit """
171
 
        from commit import OliveCommit
172
 
        commit = OliveCommit(self.gladefile, self.comm, self.dialog)
173
 
        commit.display()
 
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
        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()
174
305
    
 
306
    @show_bzr_error
175
307
    def diff(self, action):
176
308
        """ Right context menu -> Diff """
177
 
        from diff import OliveDiff
178
 
        diff = OliveDiff(self.gladefile, self.comm, self.dialog)
179
 
        diff.display()
 
309
        wt = WorkingTree.open_containing(self.path)[0]
 
310
        window = DiffWindow(self.app)
 
311
        parent_tree = wt.branch.repository.revision_tree(wt.branch.last_revision())
 
312
        window.set_diff(wt.branch.nick, wt, parent_tree)
 
313
        window.set_file(wt.relpath(self.path + os.sep + self.selected))
 
314
        window.show()
180
315
    
181
316
    def bookmark(self, action):
182
317
        """ Right context menu -> Bookmark """
183
 
        if self.comm.pref.add_bookmark(self.comm.get_path()):
184
 
            self.dialog.info_dialog(_('Bookmark successfully added'),
185
 
                                    _('The current directory was bookmarked. You can reach\nit by selecting it from the left panel.'))
 
318
        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.'))
 
321
            self.pref.write()
186
322
        else:
187
 
            self.dialog.warning_dialog(_('Location already bookmarked'),
188
 
                                       _('The current directory is already bookmarked.\nSee the left panel for reference.'))
189
 
        
190
 
        self.comm.refresh_left()
 
323
            warning_dialog(_i18n('Location already bookmarked'),
 
324
                           _i18n('The current directory is already bookmarked.\nSee the left panel for reference.'))
 
325
        
 
326
        self.app.refresh_left()
 
327
 
 
328
    def edit_bookmark(self, action):
 
329
        """ Left context menu -> Edit """
 
330
        from bookmark import BookmarkDialog
 
331
        
 
332
        if self.selected != None:
 
333
            bookmark = BookmarkDialog(self.selected, self.app.window)
 
334
            response = bookmark.run()
 
335
            
 
336
            if response != gtk.RESPONSE_NONE:
 
337
                bookmark.hide()
 
338
        
 
339
                if response == gtk.RESPONSE_OK:
 
340
                    self.app.refresh_left()
 
341
            
 
342
                bookmark.destroy()
191
343
 
192
344
    def remove_bookmark(self, action):
193
345
        """ Left context menu -> Remove """
194
 
        self.comm.pref.remove_bookmark(self.comm.get_selected_left())
195
 
        
196
 
        self.comm.refresh_left()
 
346
        
 
347
        if self.selected != None:
 
348
            self.pref.remove_bookmark(self.selected)
 
349
            self.pref.write()
 
350
        
 
351
        self.app.refresh_left()
 
352
    
 
353
    def open_folder(self, action):
 
354
        """ Left context menu -> Open Folder """
 
355
        path = self.selected
 
356
 
 
357
        if path != None:
 
358
            launch(path)
197
359
    
198
360
    def diff_selected(self, action):
199
361
        """ Diff toolbutton -> Selected... """
202
364
    def diff_all(self, action):
203
365
        """ Diff toolbutton -> All... """
204
366
        from diff import OliveDiff
205
 
        diff = OliveDiff(self.gladefile, self.comm, self.dialog)
 
367
        diff = OliveDiff(self.comm)
206
368
        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."