/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: Curtis Hovey
  • Date: 2012-02-05 05:14:11 UTC
  • mto: This revision was merged to the branch mainline in revision 775.
  • Revision ID: sinzui.is@verizon.net-20120205051411-y9ra08wae1wsfv52
Remove unneeded gtksourceview1 support.

Show diffs side-by-side

added added

removed removed

Lines of Context:
1
 
# Copyright (C) 2006 by Szilveszter Farkas (Phanatic) <szilveszter.farkas@gmail.com>
2
 
#
3
 
# This program is free software; you can redistribute it and/or modify
4
 
# it under the terms of the GNU General Public License as published by
5
 
# the Free Software Foundation; either version 2 of the License, or
6
 
# (at your option) any later version.
7
 
#
8
 
# This program is distributed in the hope that it will be useful,
9
 
# but WITHOUT ANY WARRANTY; without even the implied warranty of
10
 
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
11
 
# GNU General Public License for more details.
12
 
#
13
 
# You should have received a copy of the GNU General Public License
14
 
# along with this program; if not, write to the Free Software
15
 
# Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA
16
 
 
17
 
import os
18
 
import os.path
19
 
import shutil
20
 
import sys
21
 
 
22
 
try:
23
 
    import pygtk
24
 
    pygtk.require("2.0")
25
 
except:
26
 
    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
40
 
 
41
 
class OliveMenu:
42
 
    """ This class is responsible for building the context menus. """
43
 
    def __init__(self, path, selected, app=None):
44
 
        # 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)
157
 
 
158
 
    def right_context_menu(self):
159
 
        return self.cmenu_right
160
 
    
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
 
    def add_file(self, action):
169
 
        """ Right context menu -> Add """
170
 
        import bzrlib.add
171
 
        
172
 
        # Add only the selected file
173
 
        directory = self.path
174
 
        filename = self.selected
175
 
            
176
 
        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()
204
 
        try:
205
 
            window.annotate(wt, branch, file_id)
206
 
        finally:
207
 
            branch.unlock()
208
 
    
209
 
    @show_bzr_error
210
 
    def remove_file(self, action,delete_on_disk=0):
211
 
        """ Right context menu -> Remove """
212
 
        # 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
 
    
281
 
    def commit(self, action):
282
 
        """ 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()
304
 
    
305
 
    @show_bzr_error
306
 
    def diff(self, action):
307
 
        """ 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)
367
 
        diff.display()
368
 
    
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."