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

  • Committer: Szilveszter Farkas (Phanatic)
  • Date: 2006-09-10 21:14:28 UTC
  • mto: (0.14.1 main) (93.1.1 win32.bialix)
  • mto: This revision was merged to the branch mainline in revision 83.
  • Revision ID: Szilveszter.Farkas@gmail.com-20060910211428-e0e0b6d5e576fe52
Fix the Win32 build/install issue.

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:
24
22
    pygtk.require("2.0")
25
23
except:
26
24
    pass
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
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
 
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
 
33
 
39
34
from launch import launch
40
 
from bzrlib.plugins.gtk.olive import Preferences
41
35
 
42
36
class OliveMenu:
43
37
    """ This class is responsible for building the context menus. """
44
 
    def __init__(self, path, selected, app=None):
 
38
    def __init__(self, gladefile, comm, dialog):
45
39
        # Load the UI file
46
 
        from guifiles import UIFILENAME
47
 
 
48
 
        self.uifile = UIFILENAME
49
 
 
50
 
        # Preferences handler
51
 
        self.pref = Preferences()
52
 
        
53
 
        # Set default values
54
 
        self.path = path
55
 
        self.selected = selected
56
 
        self.app = app
 
40
        if sys.platform == 'win32':
 
41
            self.uifile = os.path.dirname(sys.executable) + "/share/olive/cmenu.ui"
 
42
        else:
 
43
            self.uifile = "/usr/share/olive/cmenu.ui"
 
44
        
 
45
        if not os.path.exists(self.uifile):
 
46
            # Load from current directory if not installed
 
47
            self.uifile = "cmenu.ui"
 
48
            # Check again
 
49
            if not os.path.exists(self.uifile):
 
50
                # Fail
 
51
                print _('UI description file cannot be found.')
 
52
                sys.exit(1)
 
53
        
 
54
        self.gladefile = gladefile
 
55
        self.comm = comm
 
56
        self.dialog = dialog
57
57
        
58
58
        # Create the file list context menu
59
59
        self.ui = gtk.UIManager()
60
60
        
61
61
        self.actiongroup = gtk.ActionGroup('context')
62
62
        self.actiongroup.add_actions([('add', gtk.STOCK_ADD,
63
 
                                       _i18n('Add'), None,
64
 
                                       _i18n('Add the selected file'),
 
63
                                       _('Add'), None,
 
64
                                       _('Add the selected file'),
65
65
                                       self.add_file),
66
66
                                      ('remove', gtk.STOCK_REMOVE,
67
 
                                       _i18n('Remove'), None,
68
 
                                       _i18n('Remove the selected file'),
 
67
                                       _('Remove'), None,
 
68
                                       _('Remove the selected file'),
69
69
                                       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
 
                                      ('rename', None,
75
 
                                       _i18n('Rename'), None,
76
 
                                       _i18n('Rename the selected file'),
77
 
                                       self.rename_file),
78
70
                                      ('open', gtk.STOCK_OPEN,
79
 
                                       _i18n('Open'), None,
80
 
                                       _i18n('Open the selected file'),
 
71
                                       _('Open'), None,
 
72
                                       _('Open the selected file'),
81
73
                                       self.open_file),
82
 
                                      ('revert', None,
83
 
                                       _i18n('Revert'), None,
84
 
                                       _i18n('Revert the changes'),
85
 
                                       self.revert),
86
74
                                      ('commit', None,
87
 
                                       _i18n('Commit'), None,
88
 
                                       _i18n('Commit the changes'),
 
75
                                       _('Commit'), None,
 
76
                                       _('Commit the changes'),
89
77
                                       self.commit),
90
 
                                      ('annotate', None,
91
 
                                       _i18n('Annotate'), None,
92
 
                                       _i18n('Annotate the selected file'),
93
 
                                       self.annotate),
94
78
                                      ('diff', None,
95
 
                                       _i18n('Diff'), None,
96
 
                                       _i18n('Show the diff of the file'),
 
79
                                       _('Diff'), None,
 
80
                                       _('Show the diff of the file'),
97
81
                                       self.diff),
98
82
                                      ('bookmark', None,
99
 
                                       _i18n('Bookmark'), None,
100
 
                                       _i18n('Bookmark current location'),
 
83
                                       _('Bookmark'), None,
 
84
                                       _('Bookmark current location'),
101
85
                                       self.bookmark),
102
86
                                      ('edit_bookmark', gtk.STOCK_EDIT,
103
 
                                       _i18n('Edit'), None,
104
 
                                       _i18n('Edit the selected bookmark'),
 
87
                                       _('Edit'), None,
 
88
                                       _('Edit the selected bookmark'),
105
89
                                       self.edit_bookmark),
106
90
                                      ('remove_bookmark', gtk.STOCK_REMOVE,
107
 
                                       _i18n('Remove'), None,
108
 
                                       _i18n('Remove the selected bookmark'),
 
91
                                       _('Remove'), None,
 
92
                                       _('Remove the selected bookmark'),
109
93
                                       self.remove_bookmark),
110
94
                                      ('open_folder', gtk.STOCK_OPEN,
111
 
                                       _i18n('Open Folder'), None,
112
 
                                       _i18n('Open bookmark folder in Nautilus'),
 
95
                                       _('Open Folder'), None,
 
96
                                       _('Open bookmark folder in Nautilus'),
113
97
                                       self.open_folder),
114
98
                                      ('diff_selected', None,
115
 
                                       _i18n('Selected...'), None,
116
 
                                       _i18n('Show the differences of the selected file'),
 
99
                                       _('Selected...'), None,
 
100
                                       _('Show the differences of the selected file'),
117
101
                                       self.diff_selected),
118
102
                                      ('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)
 
103
                                       _('All...'), None,
 
104
                                       _('Show the differences of all files'),
 
105
                                       self.diff_all)
134
106
                                     ])
135
107
        
136
108
        self.ui.insert_action_group(self.actiongroup, 0)
139
111
        self.cmenu_right = self.ui.get_widget('/context_right')
140
112
        self.cmenu_left = self.ui.get_widget('/context_left')
141
113
        self.toolbar_diff = self.ui.get_widget('/toolbar_diff')
142
 
        self.cmenu_remote = self.ui.get_widget('/context_remote')
143
114
        
144
115
        # Set icons
145
 
        # TODO: do it without using deprecated comm
146
 
        #commit_menu = self.ui.get_widget('/context_right/commit')
147
 
        #commit_image = self.comm.menuitem_branch_commit.get_image()
148
 
        #commit_pixbuf = commit_image.get_pixbuf()
149
 
        #commit_icon = gtk.Image()
150
 
        #commit_icon.set_from_pixbuf(commit_pixbuf)
151
 
        #commit_menu.set_image(commit_icon)
152
 
        #diff_menu = self.ui.get_widget('/context_right/diff')
153
 
        #diff_image = self.comm.menuitem_stats_diff.get_image()
154
 
        #diff_pixbuf = diff_image.get_pixbuf()
155
 
        #diff_icon = gtk.Image()
156
 
        #diff_icon.set_from_pixbuf(diff_pixbuf)
157
 
        #diff_menu.set_image(diff_icon)
 
116
        commit_menu = self.ui.get_widget('/context_right/commit')
 
117
        commit_image = self.comm.menuitem_branch_commit.get_image()
 
118
        commit_pixbuf = commit_image.get_pixbuf()
 
119
        commit_icon = gtk.Image()
 
120
        commit_icon.set_from_pixbuf(commit_pixbuf)
 
121
        commit_menu.set_image(commit_icon)
 
122
        diff_menu = self.ui.get_widget('/context_right/diff')
 
123
        diff_image = self.comm.menuitem_stats_diff.get_image()
 
124
        diff_pixbuf = diff_image.get_pixbuf()
 
125
        diff_icon = gtk.Image()
 
126
        diff_icon.set_from_pixbuf(diff_pixbuf)
 
127
        diff_menu.set_image(diff_icon)
158
128
 
159
129
    def right_context_menu(self):
160
130
        return self.cmenu_right
162
132
    def left_context_menu(self):
163
133
        return self.cmenu_left
164
134
    
165
 
    def remote_context_menu(self):
166
 
        return self.cmenu_remote
167
 
    
168
 
    @show_bzr_error
169
135
    def add_file(self, action):
170
136
        """ Right context menu -> Add """
171
 
        import bzrlib.add
172
 
        
173
137
        # Add only the selected file
174
 
        directory = self.path
175
 
        filename = self.selected
 
138
        directory = self.comm.get_path()
 
139
        filename = self.comm.get_selected_right()
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
 
        wt, path = WorkingTree.open_containing(os.path.join(directory, filename))
183
 
        wt.add([path])
184
 
    
185
 
    @show_bzr_error
186
 
    def annotate(self, action):
187
 
        """ Right context menu -> Annotate """
188
 
        directory = self.path
189
 
        filename = self.selected
190
 
        
191
 
        if filename is None:
192
 
            error_dialog(_i18n('No file was selected'),
193
 
                         _i18n('Please select a file from the list.'))
194
 
            return
195
 
        
196
 
        wt, path = WorkingTree.open_containing(os.path.join(directory, filename))
197
 
        
198
 
        branch = wt.branch
199
 
        file_id = wt.path2id(wt.relpath(os.path.join(directory, filename)))
200
 
        
201
 
        window = GAnnotateWindow(all=False, plain=False, parent=self.app)
202
 
        window.set_title(os.path.join(directory, filename) + " - Annotate")
203
 
        config = GAnnotateConfig(window)
204
 
        window.show()
205
 
        branch.lock_read()
 
142
            self.dialog.error_dialog(_('No file was selected'),
 
143
                                     _('Please select a file from the list,\nor choose the other option.'))
 
144
            return
 
145
        
206
146
        try:
207
 
            window.annotate(wt, branch, file_id)
208
 
        finally:
209
 
            branch.unlock()
 
147
            fileops.add([directory + '/' + filename])
 
148
        except errors.NotBranchError:
 
149
            self.dialog.error_dialog(_('Directory is not a branch'),
 
150
                                     _('You can perform this action only in a branch.'))
 
151
            return
 
152
        except:
 
153
            raise
 
154
        
 
155
        self.comm.refresh_right()
210
156
    
211
 
    @show_bzr_error
212
 
    def remove_file(self, action,delete_on_disk=0):
 
157
    def remove_file(self, action):
213
158
        """ Right context menu -> Remove """
214
159
        # Remove only the selected file
215
 
        directory = self.path
216
 
        filename = self.selected
 
160
        directory = self.comm.get_path()
 
161
        filename = self.comm.get_selected_right()
217
162
        
218
163
        if filename is None:
219
 
            error_dialog(_i18n('No file was selected'),
220
 
                         _i18n('Please select a file from the list,\nor choose the other option.'))
221
 
            return
222
 
        
223
 
        wt, path = WorkingTree.open_containing(os.path.join(directory, filename))
224
 
        wt.remove(path)
225
 
        
226
 
        if delete_on_disk:
227
 
            abs_filename = os.path.join(directory,filename)
228
 
            if os.path.isdir(abs_filename):
229
 
                response = question_dialog(_i18n('Delete directory with all directories below ?'), abs_filename )
230
 
                if response == gtk.RESPONSE_YES:
231
 
                    shutil.rmtree(abs_filename)
232
 
            else:
233
 
                os.remove(abs_filename)
234
 
                
235
 
        self.app.set_path(self.path)
236
 
        self.app.refresh_right()
237
 
        
238
 
    def remove_and_delete_file(self, action):
239
 
        """ Right context menu -> Remove and delete"""
240
 
        self.remove_file(action,delete_on_disk=1)
 
164
            self.dialog.error_dialog(_('No file was selected'),
 
165
                                     _('Please select a file from the list,\nor choose the other option.'))
 
166
            return
 
167
        
 
168
        try:
 
169
            fileops.remove([directory + '/' + filename])
 
170
        except errors.NotBranchError:
 
171
            self.dialog.error_dialog(_('Directory is not a branch'),
 
172
                                     _('You can perform this action only in a branch.'))
 
173
            return
 
174
        except errors.NotVersionedError:
 
175
            self.dialog.error_dialog(_('File not versioned'),
 
176
                                     _('The selected file is not versioned.'))
 
177
            return
 
178
        except:
 
179
            raise
 
180
        
 
181
        self.comm.refresh_right()
241
182
 
242
 
    def rename_file(self, action):
243
 
        """ Right context menu -> Rename """
244
 
        from rename import OliveRename
245
 
        wt = WorkingTree.open_containing(self.path + os.sep + self.selected)[0]
246
 
        rename = OliveRename(wt, wt.relpath(self.path), self.selected)
247
 
        rename.display()
248
 
    
249
183
    def open_file(self, action):
250
184
        """ Right context menu -> Open """
251
185
        # Open only the selected file
252
 
        filename = self.selected
 
186
        filename = self.comm.get_selected_right()
253
187
        
254
188
        if filename is None:
255
 
            error_dialog(_i18n('No file was selected'),
256
 
                         _i18n('Please select a file from the list,\nor choose the other option.'))
 
189
            self.dialog.error_dialog(_('No file was selected'),
 
190
                                     _('Please select a file from the list,\nor choose the other option.'))
257
191
            return
258
192
 
259
193
        if filename == '..':
260
 
            # TODO: how to enter a directory?
261
 
            return
 
194
            self.comm.set_path(os.path.split(self.comm.get_path())[0])
262
195
        else:
263
 
            fullpath = self.path + os.sep + filename
 
196
            fullpath = self.comm.get_path() + os.sep + filename
264
197
            if os.path.isdir(fullpath):
265
198
                # selected item is an existant directory
266
 
                # TODO: how to enter a directory?
267
 
                return
 
199
                self.comm.set_path(fullpath)
268
200
            else:
269
201
                launch(fullpath) 
 
202
        
 
203
        self.comm.refresh_right()
270
204
 
271
 
    def revert(self, action):
272
 
        """ Right context menu -> Revert """
273
 
        wt, path = WorkingTree.open_containing(self.path)
274
 
        ret = wt.revert([os.path.join(path, self.selected)])
275
 
        if ret:
276
 
            warning_dialog(_i18n('Conflicts detected'),
277
 
                           _i18n('Please have a look at the working tree before continuing.'))
278
 
        else:
279
 
            info_dialog(_i18n('Revert successful'),
280
 
                        _i18n('All files reverted to last revision.'))
281
 
        self.app.refresh_right()       
282
 
    
283
205
    def commit(self, action):
284
206
        """ Right context menu -> Commit """
285
 
        from commit import CommitDialog
286
 
        branch = None
287
 
        try:
288
 
            wt, path = WorkingTree.open_containing(self.path)
289
 
            branch = wt.branch
290
 
        except NotBranchError, e:
291
 
            path = e.path
292
 
        
293
 
        if self.selected:
294
 
            selected = os.path.join(path, self.selected)
295
 
        else:
296
 
            selected = None
297
 
        commit = CommitDialog(wt=wt, selected=selected, parent=None)
298
 
        response = commit.run()
299
 
        if response != gtk.RESPONSE_NONE:
300
 
            commit.hide()
301
 
        
302
 
            if response == gtk.RESPONSE_OK:
303
 
                self.app.refresh_right()
304
 
            
305
 
            commit.destroy()
 
207
        from commit import OliveCommit
 
208
        commit = OliveCommit(self.gladefile, self.comm, self.dialog)
 
209
        commit.display()
306
210
    
307
 
    @show_bzr_error
308
211
    def diff(self, action):
309
212
        """ Right context menu -> Diff """
310
 
        wt = WorkingTree.open_containing(self.path)[0]
311
 
        window = DiffWindow(self.app)
312
 
        parent_tree = wt.branch.repository.revision_tree(wt.branch.last_revision())
313
 
        window.set_diff(wt.branch.nick, wt, parent_tree)
314
 
        window.set_file(wt.relpath(self.path + os.sep + self.selected))
315
 
        window.show()
 
213
        from diff import OliveDiff
 
214
        diff = OliveDiff(self.gladefile, self.comm, self.dialog)
 
215
        diff.display()
316
216
    
317
217
    def bookmark(self, action):
318
218
        """ Right context menu -> Bookmark """
319
 
        if self.pref.add_bookmark(self.path):
320
 
            info_dialog(_i18n('Bookmark successfully added'),
321
 
                        _i18n('The current directory was bookmarked. You can reach\nit by selecting it from the left panel.'))
322
 
            self.pref.write()
 
219
        if self.comm.pref.add_bookmark(self.comm.get_path()):
 
220
            self.dialog.info_dialog(_('Bookmark successfully added'),
 
221
                                    _('The current directory was bookmarked. You can reach\nit by selecting it from the left panel.'))
323
222
        else:
324
 
            warning_dialog(_i18n('Location already bookmarked'),
325
 
                           _i18n('The current directory is already bookmarked.\nSee the left panel for reference.'))
 
223
            self.dialog.warning_dialog(_('Location already bookmarked'),
 
224
                                       _('The current directory is already bookmarked.\nSee the left panel for reference.'))
326
225
        
327
 
        self.app.refresh_left()
 
226
        self.comm.refresh_left()
328
227
 
329
228
    def edit_bookmark(self, action):
330
229
        """ Left context menu -> Edit """
331
 
        from bookmark import BookmarkDialog
332
 
        
333
 
        if self.selected != None:
334
 
            bookmark = BookmarkDialog(self.selected, self.app.window)
335
 
            response = bookmark.run()
336
 
            
337
 
            if response != gtk.RESPONSE_NONE:
338
 
                bookmark.hide()
339
 
        
340
 
                if response == gtk.RESPONSE_OK:
341
 
                    self.app.refresh_left()
342
 
            
343
 
                bookmark.destroy()
 
230
        from bookmark import OliveBookmark
 
231
 
 
232
        if self.comm.get_selected_left() != None:
 
233
            bookmark = OliveBookmark(self.gladefile, self.comm, self.dialog)
 
234
            bookmark.display()
344
235
 
345
236
    def remove_bookmark(self, action):
346
237
        """ Left context menu -> Remove """
347
238
        
348
 
        if self.selected != None:
349
 
            self.pref.remove_bookmark(self.selected)
350
 
            self.pref.write()
351
 
        
352
 
        self.app.refresh_left()
 
239
        if self.comm.get_selected_left() != None:
 
240
            self.comm.pref.remove_bookmark(self.comm.get_selected_left())
 
241
            self.comm.refresh_left()
353
242
    
354
243
    def open_folder(self, action):
355
244
        """ Left context menu -> Open Folder """
356
 
        path = self.selected
 
245
        path = self.comm.get_selected_left()
357
246
 
358
247
        if path != None:
359
248
            launch(path)
365
254
    def diff_all(self, action):
366
255
        """ Diff toolbutton -> All... """
367
256
        from diff import OliveDiff
368
 
        diff = OliveDiff(self.comm)
 
257
        diff = OliveDiff(self.gladefile, self.comm, self.dialog)
369
258
        diff.display()
370
 
    
371
 
    def view_remote(self, action):
372
 
        """ Remote context menu -> View contents """
373
 
        print "DEBUG: view contents."
374
 
    
375
 
    def diff_remote(self, action):
376
 
        """ Remote context menu -> Show differences """
377
 
        print "DEBUG: show differences."
378
 
    
379
 
    def revert_remote(self, action):
380
 
        """ Remote context menu -> Revert to this revision """
381
 
        print "DEBUG: revert to this revision."