/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: 2007-04-03 17:16:07 UTC
  • mfrom: (187 trunk)
  • mto: This revision was merged to the branch mainline in revision 188.
  • Revision ID: jelmer@samba.org-20070403171607-0zaskazouokrm4cq
Tags: bzr-gtk-0.15.2
PrepareĀ forĀ 0.15.2

Show diffs side-by-side

added added

removed removed

Lines of Context:
22
22
    pygtk.require("2.0")
23
23
except:
24
24
    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
33
 
 
 
25
 
 
26
import gtk
 
27
 
 
28
import bzrlib.errors as errors
 
29
from bzrlib.workingtree import WorkingTree
 
30
 
 
31
from bzrlib.plugins.gtk.dialog import error_dialog, info_dialog, warning_dialog
 
32
from errors import show_bzr_error
34
33
from launch import launch
 
34
from olive import Preferences, DiffWindow
35
35
 
36
36
class OliveMenu:
37
37
    """ This class is responsible for building the context menus. """
38
 
    def __init__(self, gladefile, comm, dialog):
 
38
    def __init__(self, path, selected, app=None):
39
39
        # Load the UI file
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
 
40
        from guifiles import UIFILENAME
 
41
 
 
42
        self.uifile = UIFILENAME
 
43
 
 
44
        # Preferences handler
 
45
        self.pref = Preferences()
 
46
        
 
47
        # Set default values
 
48
        self.path = path
 
49
        self.selected = selected
 
50
        self.app = app
57
51
        
58
52
        # Create the file list context menu
59
53
        self.ui = gtk.UIManager()
67
61
                                       _('Remove'), None,
68
62
                                       _('Remove the selected file'),
69
63
                                       self.remove_file),
 
64
                                      ('rename', None,
 
65
                                       _('Rename'), None,
 
66
                                       _('Rename the selected file'),
 
67
                                       self.rename_file),
70
68
                                      ('open', gtk.STOCK_OPEN,
71
69
                                       _('Open'), None,
72
70
                                       _('Open the selected file'),
73
71
                                       self.open_file),
 
72
                                      ('revert', None,
 
73
                                       _('Revert'), None,
 
74
                                       _('Revert the changes'),
 
75
                                       self.revert),
74
76
                                      ('commit', None,
75
77
                                       _('Commit'), None,
76
78
                                       _('Commit the changes'),
113
115
        self.toolbar_diff = self.ui.get_widget('/toolbar_diff')
114
116
        
115
117
        # Set icons
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)
 
118
        # TODO: do it without using deprecated comm
 
119
        #commit_menu = self.ui.get_widget('/context_right/commit')
 
120
        #commit_image = self.comm.menuitem_branch_commit.get_image()
 
121
        #commit_pixbuf = commit_image.get_pixbuf()
 
122
        #commit_icon = gtk.Image()
 
123
        #commit_icon.set_from_pixbuf(commit_pixbuf)
 
124
        #commit_menu.set_image(commit_icon)
 
125
        #diff_menu = self.ui.get_widget('/context_right/diff')
 
126
        #diff_image = self.comm.menuitem_stats_diff.get_image()
 
127
        #diff_pixbuf = diff_image.get_pixbuf()
 
128
        #diff_icon = gtk.Image()
 
129
        #diff_icon.set_from_pixbuf(diff_pixbuf)
 
130
        #diff_menu.set_image(diff_icon)
128
131
 
129
132
    def right_context_menu(self):
130
133
        return self.cmenu_right
132
135
    def left_context_menu(self):
133
136
        return self.cmenu_left
134
137
    
 
138
    @show_bzr_error
135
139
    def add_file(self, action):
136
140
        """ Right context menu -> Add """
 
141
        import bzrlib.add
 
142
        
137
143
        # Add only the selected file
138
 
        directory = self.comm.get_path()
139
 
        filename = self.comm.get_selected_right()
 
144
        directory = self.path
 
145
        filename = self.selected
140
146
            
141
147
        if filename is None:
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
 
        
146
 
        try:
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()
 
148
            error_dialog(_('No file was selected'),
 
149
                         _('Please select a file from the list,\nor choose the other option.'))
 
150
            return
 
151
        
 
152
        bzrlib.add.smart_add([os.path.join(directory, filename)])
156
153
    
 
154
    @show_bzr_error
157
155
    def remove_file(self, action):
158
156
        """ Right context menu -> Remove """
159
157
        # Remove only the selected file
160
 
        directory = self.comm.get_path()
161
 
        filename = self.comm.get_selected_right()
 
158
        directory = self.path
 
159
        filename = self.selected
162
160
        
163
161
        if filename is None:
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()
 
162
            error_dialog(_('No file was selected'),
 
163
                         _('Please select a file from the list,\nor choose the other option.'))
 
164
            return
 
165
        
 
166
        wt, path = WorkingTree.open_containing(os.path.join(directory, filename))
 
167
        wt.remove(path)
 
168
        self.app.set_path(self.path)
 
169
        self.app.refresh_right()
182
170
 
 
171
    def rename_file(self, action):
 
172
        """ Right context menu -> Rename """
 
173
        from rename import OliveRename
 
174
        wt = WorkingTree.open_containing(self.path + os.sep + self.selected)[0]
 
175
        rename = OliveRename(wt, wt.relpath(self.path), self.selected)
 
176
        rename.display()
 
177
    
183
178
    def open_file(self, action):
184
179
        """ Right context menu -> Open """
185
180
        # Open only the selected file
186
 
        filename = self.comm.get_selected_right()
 
181
        filename = self.selected
187
182
        
188
183
        if filename is None:
189
 
            self.dialog.error_dialog(_('No file was selected'),
190
 
                                     _('Please select a file from the list,\nor choose the other option.'))
 
184
            error_dialog(_('No file was selected'),
 
185
                         _('Please select a file from the list,\nor choose the other option.'))
191
186
            return
192
187
 
193
188
        if filename == '..':
194
 
            self.comm.set_path(os.path.split(self.comm.get_path())[0])
 
189
            # TODO: how to enter a directory?
 
190
            return
195
191
        else:
196
 
            fullpath = self.comm.get_path() + os.sep + filename
 
192
            fullpath = self.path + os.sep + filename
197
193
            if os.path.isdir(fullpath):
198
194
                # selected item is an existant directory
199
 
                self.comm.set_path(fullpath)
 
195
                # TODO: how to enter a directory?
 
196
                return
200
197
            else:
201
198
                launch(fullpath) 
202
 
        
203
 
        self.comm.refresh_right()
204
199
 
 
200
    def revert(self, action):
 
201
        """ Right context menu -> Revert """
 
202
        wt, path = WorkingTree.open_containing(self.path)
 
203
        ret = wt.revert([os.path.join(path, self.selected)])
 
204
        if ret:
 
205
            warning_dialog(_('Conflicts detected'),
 
206
                           _('Please have a look at the working tree before continuing.'))
 
207
        else:
 
208
            info_dialog(_('Revert successful'),
 
209
                        _('All files reverted to last revision.'))
 
210
        self.app.refresh_right()       
 
211
    
205
212
    def commit(self, action):
206
213
        """ Right context menu -> Commit """
207
 
        from commit import OliveCommit
208
 
        commit = OliveCommit(self.gladefile, self.comm, self.dialog)
209
 
        commit.display()
 
214
        from commit import CommitDialog
 
215
        branch = None
 
216
        try:
 
217
            wt, path = WorkingTree.open_containing(self.path)
 
218
            branch = wt.branch
 
219
        except NotBranchError, e:
 
220
            path = e.path
 
221
        
 
222
        commit = CommitDialog(wt, path, not branch, self.selected)
 
223
        response = commit.run()
 
224
        if response != gtk.RESPONSE_NONE:
 
225
            commit.hide()
 
226
        
 
227
            if response == gtk.RESPONSE_OK:
 
228
                self.app.refresh_right()
 
229
            
 
230
            commit.destroy()
210
231
    
 
232
    @show_bzr_error
211
233
    def diff(self, action):
212
234
        """ Right context menu -> Diff """
213
 
        from diff import OliveDiff
214
 
        diff = OliveDiff(self.gladefile, self.comm, self.dialog)
215
 
        diff.display()
 
235
        wt = WorkingTree.open_containing(self.path)[0]
 
236
        window = DiffWindow()
 
237
        parent_tree = wt.branch.repository.revision_tree(wt.branch.last_revision())
 
238
        window.set_diff(wt.branch.nick, wt, parent_tree)
 
239
        window.set_file(wt.relpath(self.path + os.sep + self.selected))
 
240
        window.show()
216
241
    
217
242
    def bookmark(self, action):
218
243
        """ Right context menu -> Bookmark """
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.'))
 
244
        if self.pref.add_bookmark(self.path):
 
245
            info_dialog(_('Bookmark successfully added'),
 
246
                        _('The current directory was bookmarked. You can reach\nit by selecting it from the left panel.'))
 
247
            self.pref.write()
222
248
        else:
223
 
            self.dialog.warning_dialog(_('Location already bookmarked'),
224
 
                                       _('The current directory is already bookmarked.\nSee the left panel for reference.'))
 
249
            warning_dialog(_('Location already bookmarked'),
 
250
                           _('The current directory is already bookmarked.\nSee the left panel for reference.'))
225
251
        
226
 
        self.comm.refresh_left()
 
252
        self.app.refresh_left()
227
253
 
228
254
    def edit_bookmark(self, action):
229
255
        """ Left context menu -> Edit """
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()
 
256
        from bookmark import BookmarkDialog
 
257
        
 
258
        if self.selected != None:
 
259
            bookmark = BookmarkDialog(self.selected, self.app.window)
 
260
            response = bookmark.run()
 
261
            
 
262
            if response != gtk.RESPONSE_NONE:
 
263
                bookmark.hide()
 
264
        
 
265
                if response == gtk.RESPONSE_OK:
 
266
                    self.app.refresh_left()
 
267
            
 
268
                bookmark.destroy()
235
269
 
236
270
    def remove_bookmark(self, action):
237
271
        """ Left context menu -> Remove """
238
272
        
239
 
        if self.comm.get_selected_left() != None:
240
 
            self.comm.pref.remove_bookmark(self.comm.get_selected_left())
241
 
            self.comm.refresh_left()
 
273
        if self.selected != None:
 
274
            self.pref.remove_bookmark(self.selected)
 
275
            self.pref.write()
 
276
        
 
277
        self.app.refresh_left()
242
278
    
243
279
    def open_folder(self, action):
244
280
        """ Left context menu -> Open Folder """
245
 
        path = self.comm.get_selected_left()
 
281
        path = self.selected
246
282
 
247
283
        if path != None:
248
284
            launch(path)
254
290
    def diff_all(self, action):
255
291
        """ Diff toolbutton -> All... """
256
292
        from diff import OliveDiff
257
 
        diff = OliveDiff(self.gladefile, self.comm, self.dialog)
 
293
        diff = OliveDiff(self.comm)
258
294
        diff.display()