/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-08-07 16:51:21 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-20060807165121-10fe27c374bbdffd
Added new artwork.

2006-08-07  Szilveszter Farkas <Szilveszter.Farkas@gmail.com>

    * olive.galde: added custom artwork (icons)
    * icons/*: new icons for the toolbar
    * setup.py: install the icons

Show diffs side-by-side

added added

removed removed

Lines of Context:
1
1
# Copyright (C) 2006 by Szilveszter Farkas (Phanatic) <szilveszter.farkas@gmail.com>
2
 
#
 
2
 
3
3
# This program is free software; you can redistribute it and/or modify
4
4
# it under the terms of the GNU General Public License as published by
5
5
# the Free Software Foundation; either version 2 of the License, or
6
6
# (at your option) any later version.
7
 
#
 
7
 
8
8
# This program is distributed in the hope that it will be useful,
9
9
# but WITHOUT ANY WARRANTY; without even the implied warranty of
10
10
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
11
11
# GNU General Public License for more details.
12
 
#
 
12
 
13
13
# You should have received a copy of the GNU General Public License
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.dialog import error_dialog, info_dialog, question_dialog, warning_dialog
34
 
from bzrlib.plugins.gtk.errors import show_bzr_error
35
 
from bzrlib.plugins.gtk.annotate.gannotate import GAnnotateWindow
36
 
from bzrlib.plugins.gtk.annotate.config import GAnnotateConfig
37
 
from bzrlib.plugins.gtk.diff import DiffWindow
38
 
from launch import launch
39
 
from olive import Preferences
 
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
 
 
34
from commit import OliveCommit
 
35
from diff import OliveDiff
40
36
 
41
37
class OliveMenu:
42
38
    """ This class is responsible for building the context menus. """
43
 
    def __init__(self, path, selected, app=None):
 
39
    def __init__(self, gladefile, comm, dialog):
44
40
        # Load the UI file
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
56
 
        
57
 
        # Create the file list context menu
58
 
        self.ui = gtk.UIManager()
59
 
        
60
 
        self.actiongroup = gtk.ActionGroup('context')
61
 
        self.actiongroup.add_actions([('add', gtk.STOCK_ADD,
62
 
                                       _('Add'), None,
63
 
                                       _('Add the selected file'),
64
 
                                       self.add_file),
65
 
                                      ('remove', gtk.STOCK_REMOVE,
66
 
                                       _('Remove'), None,
67
 
                                       _('Remove the selected file'),
68
 
                                       self.remove_file),
69
 
                                      ('remove_and_delete', gtk.STOCK_REMOVE,
70
 
                                       _('Remove and delete'), None,
71
 
                                       _('Remove the selected file/dir and delete from disk'),
72
 
                                       self.remove_and_delete_file),
73
 
                                      ('rename', None,
74
 
                                       _('Rename'), None,
75
 
                                       _('Rename the selected file'),
76
 
                                       self.rename_file),
77
 
                                      ('open', gtk.STOCK_OPEN,
78
 
                                       _('Open'), None,
79
 
                                       _('Open the selected file'),
80
 
                                       self.open_file),
81
 
                                      ('revert', None,
82
 
                                       _('Revert'), None,
83
 
                                       _('Revert the changes'),
84
 
                                       self.revert),
85
 
                                      ('commit', None,
86
 
                                       _('Commit'), None,
87
 
                                       _('Commit the changes'),
88
 
                                       self.commit),
89
 
                                      ('annotate', None,
90
 
                                       _('Annotate'), None,
91
 
                                       _('Annotate the selected file'),
92
 
                                       self.annotate),
93
 
                                      ('diff', None,
94
 
                                       _('Diff'), None,
95
 
                                       _('Show the diff of the file'),
96
 
                                       self.diff),
97
 
                                      ('bookmark', None,
98
 
                                       _('Bookmark'), None,
99
 
                                       _('Bookmark current location'),
100
 
                                       self.bookmark),
101
 
                                      ('edit_bookmark', gtk.STOCK_EDIT,
102
 
                                       _('Edit'), None,
103
 
                                       _('Edit the selected bookmark'),
104
 
                                       self.edit_bookmark),
105
 
                                      ('remove_bookmark', gtk.STOCK_REMOVE,
106
 
                                       _('Remove'), None,
107
 
                                       _('Remove the selected bookmark'),
108
 
                                       self.remove_bookmark),
109
 
                                      ('open_folder', gtk.STOCK_OPEN,
110
 
                                       _('Open Folder'), None,
111
 
                                       _('Open bookmark folder in Nautilus'),
112
 
                                       self.open_folder),
113
 
                                      ('diff_selected', None,
114
 
                                       _('Selected...'), None,
115
 
                                       _('Show the differences of the selected file'),
116
 
                                       self.diff_selected),
117
 
                                      ('diff_all', None,
118
 
                                       _('All...'), None,
119
 
                                       _('Show the differences of all files'),
120
 
                                       self.diff_all),
121
 
                                      ('view_remote', None,
122
 
                                       _('View contents'), None,
123
 
                                       _('View the contents of the file in a builtin viewer'),
124
 
                                       self.view_remote),
125
 
                                      ('diff_remote', None,
126
 
                                       _('Show differences'), None,
127
 
                                       _('Show the differences between two revisions of the file'),
128
 
                                       self.diff_remote),
129
 
                                      ('revert_remote', None,
130
 
                                       _('Revert to this revision'), None,
131
 
                                       _('Revert the selected file to the selected revision'),
132
 
                                       self.revert_remote)
133
 
                                     ])
134
 
        
135
 
        self.ui.insert_action_group(self.actiongroup, 0)
136
 
        self.ui.add_ui_from_file(self.uifile)
137
 
        
138
 
        self.cmenu_right = self.ui.get_widget('/context_right')
139
 
        self.cmenu_left = self.ui.get_widget('/context_left')
140
 
        self.toolbar_diff = self.ui.get_widget('/toolbar_diff')
141
 
        self.cmenu_remote = self.ui.get_widget('/context_remote')
142
 
        
143
 
        # Set icons
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)
 
41
        self.uifile = "/usr/share/olive/cmenu.ui"
 
42
        if not os.path.exists(self.uifile):
 
43
            # Load from current directory if not installed
 
44
            self.uifile = "cmenu.ui"
 
45
        
 
46
        self.gladefile = gladefile
 
47
        self.comm = comm
 
48
        self.dialog = dialog
 
49
        
 
50
        self.ui_right = gtk.UIManager()
 
51
        
 
52
        self.actiongroup_right = gtk.ActionGroup('context_right')
 
53
        self.actiongroup_right.add_actions([('add', gtk.STOCK_ADD,
 
54
                                             'Add', None,
 
55
                                             'Add the selected file',
 
56
                                             self.add_file),
 
57
                                            ('remove', gtk.STOCK_REMOVE,
 
58
                                             'Remove', None,
 
59
                                             'Remove the selected file',
 
60
                                             self.remove_file),
 
61
                                            ('commit', gtk.STOCK_REDO,
 
62
                                             'Commit', None,
 
63
                                             'Commit the changes',
 
64
                                             self.commit),
 
65
                                            ('diff', None,
 
66
                                             'Diff', None,
 
67
                                             'Show the diff of the file',
 
68
                                             self.diff),
 
69
                                            ('log', None,
 
70
                                             'Log', None,
 
71
                                             'Show the log of the file',
 
72
                                             self.log)])
 
73
        
 
74
        self.ui_right.insert_action_group(self.actiongroup_right, 0)
 
75
        self.ui_right.add_ui_from_file(self.uifile)
 
76
        
 
77
        self.cmenu_right = self.ui_right.get_widget('/context_right')
157
78
 
158
79
    def right_context_menu(self):
159
80
        return self.cmenu_right
160
81
    
161
 
    def left_context_menu(self):
162
 
        return self.cmenu_left
163
 
    
164
 
    def remote_context_menu(self):
165
 
        return self.cmenu_remote
166
 
    
167
 
    @show_bzr_error
168
82
    def add_file(self, action):
169
83
        """ Right context menu -> Add """
170
 
        import bzrlib.add
171
 
        
172
84
        # Add only the selected file
173
 
        directory = self.path
174
 
        filename = self.selected
 
85
        directory = self.comm.get_path()
 
86
        filename = self.comm.get_selected_right()
175
87
            
176
88
        if filename is None:
177
 
            error_dialog(_('No file was selected'),
178
 
                         _('Please select a file from the list,\nor choose the other option.'))
179
 
            return
180
 
        
181
 
        bzrlib.add.smart_add([os.path.join(directory, filename)])
182
 
    
183
 
    @show_bzr_error
184
 
    def annotate(self, action):
185
 
        """ Right context menu -> Annotate """
186
 
        directory = self.path
187
 
        filename = self.selected
188
 
        
189
 
        if filename is None:
190
 
            error_dialog(_('No file was selected'),
191
 
                         _('Please select a file from the list.'))
192
 
            return
193
 
        
194
 
        wt, path = WorkingTree.open_containing(os.path.join(directory, filename))
195
 
        
196
 
        branch = wt.branch
197
 
        file_id = wt.path2id(wt.relpath(os.path.join(directory, filename)))
198
 
        
199
 
        window = GAnnotateWindow(all=False, plain=False, parent=self.app)
200
 
        window.set_title(os.path.join(directory, filename) + " - Annotate")
201
 
        config = GAnnotateConfig(window)
202
 
        window.show()
203
 
        branch.lock_read()
 
89
            self.dialog.error_dialog('No file was selected.')
 
90
            return
 
91
        
204
92
        try:
205
 
            window.annotate(wt, branch, file_id)
206
 
        finally:
207
 
            branch.unlock()
 
93
            fileops.add([directory + '/' + filename])
 
94
        except errors.NotBranchError:
 
95
            self.dialog.error_dialog('The directory is not a branch.')
 
96
            return
 
97
        except:
 
98
            raise
 
99
        
 
100
        self.comm.refresh_right()
208
101
    
209
 
    @show_bzr_error
210
 
    def remove_file(self, action,delete_on_disk=0):
 
102
    def remove_file(self, action):
211
103
        """ Right context menu -> Remove """
212
104
        # Remove only the selected file
213
 
        directory = self.path
214
 
        filename = self.selected
215
 
        
216
 
        if filename is None:
217
 
            error_dialog(_('No file was selected'),
218
 
                         _('Please select a file from the list,\nor choose the other option.'))
219
 
            return
220
 
        
221
 
        wt, path = WorkingTree.open_containing(os.path.join(directory, filename))
222
 
        wt.remove(path)
223
 
        
224
 
        if delete_on_disk:
225
 
            abs_filename = os.path.join(directory,filename)
226
 
            if os.path.isdir(abs_filename):
227
 
                response = question_dialog(_('Delete directory with all directories below ?'), abs_filename )
228
 
                if response == gtk.RESPONSE_YES:
229
 
                    shutil.rmtree(abs_filename)
230
 
            else:
231
 
                os.remove(abs_filename)
232
 
                
233
 
        self.app.set_path(self.path)
234
 
        self.app.refresh_right()
235
 
        
236
 
    def remove_and_delete_file(self, action):
237
 
        """ Right context menu -> Remove and delete"""
238
 
        self.remove_file(action,delete_on_disk=1)
239
 
 
240
 
    def rename_file(self, action):
241
 
        """ Right context menu -> Rename """
242
 
        from rename import OliveRename
243
 
        wt = WorkingTree.open_containing(self.path + os.sep + self.selected)[0]
244
 
        rename = OliveRename(wt, wt.relpath(self.path), self.selected)
245
 
        rename.display()
246
 
    
247
 
    def open_file(self, action):
248
 
        """ Right context menu -> Open """
249
 
        # Open only the selected file
250
 
        filename = self.selected
251
 
        
252
 
        if filename is None:
253
 
            error_dialog(_('No file was selected'),
254
 
                         _('Please select a file from the list,\nor choose the other option.'))
255
 
            return
256
 
 
257
 
        if filename == '..':
258
 
            # TODO: how to enter a directory?
259
 
            return
260
 
        else:
261
 
            fullpath = self.path + os.sep + filename
262
 
            if os.path.isdir(fullpath):
263
 
                # selected item is an existant directory
264
 
                # TODO: how to enter a directory?
265
 
                return
266
 
            else:
267
 
                launch(fullpath) 
268
 
 
269
 
    def revert(self, action):
270
 
        """ Right context menu -> Revert """
271
 
        wt, path = WorkingTree.open_containing(self.path)
272
 
        ret = wt.revert([os.path.join(path, self.selected)])
273
 
        if ret:
274
 
            warning_dialog(_('Conflicts detected'),
275
 
                           _('Please have a look at the working tree before continuing.'))
276
 
        else:
277
 
            info_dialog(_('Revert successful'),
278
 
                        _('All files reverted to last revision.'))
279
 
        self.app.refresh_right()       
280
 
    
 
105
        directory = self.comm.get_path()
 
106
        filename = self.comm.get_selected_right()
 
107
        
 
108
        if filename is None:
 
109
            self.dialog.error_dialog('No file was selected.')
 
110
            return
 
111
        
 
112
        try:
 
113
            fileops.remove([directory + '/' + filename])
 
114
        except errors.NotBranchError:
 
115
            self.dialog.error_dialog('The directory is not a branch.')
 
116
            return
 
117
        except errors.NotVersionedError:
 
118
            self.dialog.error_dialog('Selected file is not versioned.')
 
119
            return
 
120
        except:
 
121
            raise
 
122
        
 
123
        self.comm.refresh_right()
 
124
 
281
125
    def commit(self, action):
282
126
        """ Right context menu -> Commit """
283
 
        from commit import CommitDialog
284
 
        branch = None
285
 
        try:
286
 
            wt, path = WorkingTree.open_containing(self.path)
287
 
            branch = wt.branch
288
 
        except NotBranchError, e:
289
 
            path = e.path
290
 
        
291
 
        if self.selected:
292
 
            selected = os.path.join(path, self.selected)
293
 
        else:
294
 
            selected = None
295
 
        commit = CommitDialog(wt=wt, selected=selected, parent=None)
296
 
        response = commit.run()
297
 
        if response != gtk.RESPONSE_NONE:
298
 
            commit.hide()
299
 
        
300
 
            if response == gtk.RESPONSE_OK:
301
 
                self.app.refresh_right()
302
 
            
303
 
            commit.destroy()
 
127
        commit = OliveCommit(self.gladefile, self.comm)
 
128
        commit.display()
304
129
    
305
 
    @show_bzr_error
306
130
    def diff(self, action):
307
131
        """ Right context menu -> Diff """
308
 
        wt = WorkingTree.open_containing(self.path)[0]
309
 
        window = DiffWindow(self.app)
310
 
        parent_tree = wt.branch.repository.revision_tree(wt.branch.last_revision())
311
 
        window.set_diff(wt.branch.nick, wt, parent_tree)
312
 
        window.set_file(wt.relpath(self.path + os.sep + self.selected))
313
 
        window.show()
314
 
    
315
 
    def bookmark(self, action):
316
 
        """ Right context menu -> Bookmark """
317
 
        if self.pref.add_bookmark(self.path):
318
 
            info_dialog(_('Bookmark successfully added'),
319
 
                        _('The current directory was bookmarked. You can reach\nit by selecting it from the left panel.'))
320
 
            self.pref.write()
321
 
        else:
322
 
            warning_dialog(_('Location already bookmarked'),
323
 
                           _('The current directory is already bookmarked.\nSee the left panel for reference.'))
324
 
        
325
 
        self.app.refresh_left()
326
 
 
327
 
    def edit_bookmark(self, action):
328
 
        """ Left context menu -> Edit """
329
 
        from bookmark import BookmarkDialog
330
 
        
331
 
        if self.selected != None:
332
 
            bookmark = BookmarkDialog(self.selected, self.app.window)
333
 
            response = bookmark.run()
334
 
            
335
 
            if response != gtk.RESPONSE_NONE:
336
 
                bookmark.hide()
337
 
        
338
 
                if response == gtk.RESPONSE_OK:
339
 
                    self.app.refresh_left()
340
 
            
341
 
                bookmark.destroy()
342
 
 
343
 
    def remove_bookmark(self, action):
344
 
        """ Left context menu -> Remove """
345
 
        
346
 
        if self.selected != None:
347
 
            self.pref.remove_bookmark(self.selected)
348
 
            self.pref.write()
349
 
        
350
 
        self.app.refresh_left()
351
 
    
352
 
    def open_folder(self, action):
353
 
        """ Left context menu -> Open Folder """
354
 
        path = self.selected
355
 
 
356
 
        if path != None:
357
 
            launch(path)
358
 
    
359
 
    def diff_selected(self, action):
360
 
        """ Diff toolbutton -> Selected... """
361
 
        print "DEBUG: not implemented."
362
 
    
363
 
    def diff_all(self, action):
364
 
        """ Diff toolbutton -> All... """
365
 
        from diff import OliveDiff
366
 
        diff = OliveDiff(self.comm)
 
132
        diff = OliveDiff(self.gladefile, self.comm)
367
133
        diff.display()
368
134
    
369
 
    def view_remote(self, action):
370
 
        """ Remote context menu -> View contents """
371
 
        print "DEBUG: view contents."
372
 
    
373
 
    def diff_remote(self, action):
374
 
        """ Remote context menu -> Show differences """
375
 
        print "DEBUG: show differences."
376
 
    
377
 
    def revert_remote(self, action):
378
 
        """ Remote context menu -> Revert to this revision """
379
 
        print "DEBUG: revert to this revision."
 
135
    def log(self, action):
 
136
        """ Right context menu -> Log """
 
137
        self.dialog.error_dialog('This feature is not yet implemented.')