30
28
import bzrlib.errors as errors
 
31
29
from bzrlib.workingtree import WorkingTree
 
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
 
39
 
from bzrlib.plugins.gtk.olive import Preferences, launch
 
 
31
from dialog import error_dialog, info_dialog, warning_dialog
 
 
32
from launch import launch
 
 
33
from olive import OlivePreferences, DiffWindow
 
42
36
    """ This class is responsible for building the context menus. """
 
 
60
54
        self.actiongroup = gtk.ActionGroup('context')
 
61
55
        self.actiongroup.add_actions([('add', gtk.STOCK_ADD,
 
63
 
                                       _i18n('Add the selected file'),
 
 
57
                                       _('Add the selected file'),
 
65
59
                                      ('remove', gtk.STOCK_REMOVE,
 
66
 
                                       _i18n('Remove'), None,
 
67
 
                                       _i18n('Remove the selected file'),
 
 
61
                                       _('Remove the selected 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),
 
74
 
                                       _i18n('Rename'), None,
 
75
 
                                       _i18n('Rename the selected file'),
 
 
65
                                       _('Rename the selected file'),
 
77
67
                                      ('open', gtk.STOCK_OPEN,
 
79
 
                                       _i18n('Open the selected file'),
 
 
69
                                       _('Open the selected file'),
 
82
 
                                       _i18n('Revert'), None,
 
83
 
                                       _i18n('Revert the changes'),
 
86
 
                                       _i18n('Commit'), None,
 
87
 
                                       _i18n('Commit the changes'),
 
 
73
                                       _('Commit the changes'),
 
90
 
                                       _i18n('Annotate'), None,
 
91
 
                                       _i18n('Annotate the selected file'),
 
95
 
                                       _i18n('Show the diff of the file'),
 
 
77
                                       _('Show the diff of the file'),
 
98
 
                                       _i18n('Bookmark'), None,
 
99
 
                                       _i18n('Bookmark current location'),
 
 
81
                                       _('Bookmark current location'),
 
101
83
                                      ('edit_bookmark', gtk.STOCK_EDIT,
 
103
 
                                       _i18n('Edit the selected bookmark'),
 
 
85
                                       _('Edit the selected bookmark'),
 
104
86
                                       self.edit_bookmark),
 
105
87
                                      ('remove_bookmark', gtk.STOCK_REMOVE,
 
106
 
                                       _i18n('Remove'), None,
 
107
 
                                       _i18n('Remove the selected bookmark'),
 
 
89
                                       _('Remove the selected bookmark'),
 
108
90
                                       self.remove_bookmark),
 
109
91
                                      ('open_folder', gtk.STOCK_OPEN,
 
110
 
                                       _i18n('Open Folder'), None,
 
111
 
                                       _i18n('Open bookmark folder in Nautilus'),
 
 
92
                                       _('Open Folder'), None,
 
 
93
                                       _('Open bookmark folder in Nautilus'),
 
112
94
                                       self.open_folder),
 
113
95
                                      ('diff_selected', None,
 
114
 
                                       _i18n('Selected...'), None,
 
115
 
                                       _i18n('Show the differences of the selected file'),
 
 
96
                                       _('Selected...'), None,
 
 
97
                                       _('Show the differences of the selected file'),
 
116
98
                                       self.diff_selected),
 
117
99
                                      ('diff_all', None,
 
118
 
                                       _i18n('All...'), None,
 
119
 
                                       _i18n('Show the differences of all files'),
 
121
 
                                      ('view_remote', None,
 
122
 
                                       _i18n('View contents'), None,
 
123
 
                                       _i18n('View the contents of the file in a builtin viewer'),
 
125
 
                                      ('diff_remote', None,
 
126
 
                                       _i18n('Show differences'), None,
 
127
 
                                       _i18n('Show the differences between two revisions of the file'),
 
129
 
                                      ('revert_remote', None,
 
130
 
                                       _i18n('Revert to this revision'), None,
 
131
 
                                       _i18n('Revert the selected file to the selected revision'),
 
 
101
                                       _('Show the differences of all files'),
 
135
105
        self.ui.insert_action_group(self.actiongroup, 0)
 
 
174
139
        filename = self.selected
 
176
141
        if filename is None:
 
177
 
            error_dialog(_i18n('No file was selected'),
 
178
 
                         _i18n('Please select a file from the list,\nor choose the other option.'))
 
181
 
        wt, path = WorkingTree.open_containing(os.path.join(directory, filename))
 
184
 
        self.app.refresh_right()
 
187
 
    def annotate(self, action):
 
188
 
        """ Right context menu -> Annotate """
 
189
 
        directory = self.path
 
190
 
        filename = self.selected
 
193
 
            error_dialog(_i18n('No file was selected'),
 
194
 
                         _i18n('Please select a file from the list.'))
 
197
 
        wt, path = WorkingTree.open_containing(os.path.join(directory, filename))
 
200
 
        file_id = wt.path2id(wt.relpath(os.path.join(directory, filename)))
 
202
 
            raise errors.NotVersionedError(filename)
 
203
 
        window = GAnnotateWindow(all=False, plain=False, parent=self.app)
 
204
 
        window.set_title(os.path.join(directory, filename) + " - Annotate")
 
205
 
        config = GAnnotateConfig(window)
 
 
142
            error_dialog(_('No file was selected'),
 
 
143
                         _('Please select a file from the list,\nor choose the other option.'))
 
209
 
            window.annotate(wt, branch, file_id)
 
 
147
            bzrlib.add.smart_add([os.path.join(directory, filename)])
 
 
148
        except errors.NotBranchError:
 
 
149
            error_dialog(_('Directory is not a branch'),
 
 
150
                         _('You can perform this action only in a branch.'))
 
214
 
    def remove_file(self, action, delete_on_disk=False):
 
 
153
    def remove_file(self, action):
 
215
154
        """ Right context menu -> Remove """
 
216
155
        # Remove only the selected file
 
217
156
        directory = self.path
 
218
157
        filename = self.selected
 
220
159
        if filename is None:
 
221
 
            error_dialog(_i18n('No file was selected'),
 
222
 
                         _i18n('Please select a file from the list,\nor choose the other option.'))
 
225
 
        wt, path = WorkingTree.open_containing(os.path.join(directory, filename))
 
229
 
            abs_filename = os.path.join(directory,filename)
 
230
 
            if os.path.isdir(abs_filename):
 
231
 
                response = question_dialog(_i18n('Delete directory with all directories below ?'), abs_filename )
 
232
 
                if response == gtk.RESPONSE_YES:
 
233
 
                    shutil.rmtree(abs_filename)
 
235
 
                os.remove(abs_filename)
 
 
160
            error_dialog(_('No file was selected'),
 
 
161
                         _('Please select a file from the list,\nor choose the other option.'))
 
 
165
            wt, path = WorkingTree.open_containing(os.path.join(directory, filename))
 
 
168
        except errors.NotBranchError:
 
 
169
            error_dialog(_('Directory is not a branch'),
 
 
170
                         _('You can perform this action only in a branch.'))
 
 
172
        except errors.NotVersionedError:
 
 
173
            error_dialog(_('File not versioned'),
 
 
174
                         _('The selected file is not versioned.'))
 
237
177
        self.app.set_path(self.path)
 
238
178
        self.app.refresh_right()
 
240
 
    def remove_and_delete_file(self, action):
 
241
 
        """ Right context menu -> Remove and delete"""
 
242
 
        self.remove_file(action, delete_on_disk=True)
 
244
180
    def rename_file(self, action):
 
245
181
        """ Right context menu -> Rename """
 
246
 
        from bzrlib.plugins.gtk.olive.rename import RenameDialog
 
247
 
        wt = WorkingTree.open_containing(os.path.join(self.path, self.selected))[0]
 
248
 
        rename = RenameDialog(wt, wt.relpath(self.path), self.selected)
 
249
 
        response = rename.run()
 
251
 
        if response == gtk.RESPONSE_OK:
 
252
 
            self.app.refresh_right()
 
 
182
        from rename import OliveRename
 
 
183
        wt = WorkingTree.open_containing(self.path + os.sep + self.selected)[0]
 
 
184
        rename = OliveRename(wt, wt.relpath(self.path), self.selected)
 
254
187
    def open_file(self, action):
 
255
188
        """ Right context menu -> Open """
 
 
257
190
        filename = self.selected
 
259
192
        if filename is None:
 
260
 
            error_dialog(_i18n('No file was selected'),
 
261
 
                         _i18n('Please select a file from the list,\nor choose the other option.'))
 
 
193
            error_dialog(_('No file was selected'),
 
 
194
                         _('Please select a file from the list,\nor choose the other option.'))
 
264
197
        if filename == '..':
 
265
198
            # TODO: how to enter a directory?
 
268
 
            fullpath = os.path.join(self.path, filename)
 
269
 
            launch.launch(fullpath) 
 
 
201
            fullpath = self.path + os.sep + filename
 
 
202
            if os.path.isdir(fullpath):
 
 
203
                # selected item is an existant directory
 
 
204
                # TODO: how to enter a directory?
 
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)])
 
276
 
            warning_dialog(_i18n('Conflicts detected'),
 
277
 
                           _i18n('Please have a look at the working tree before continuing.'))
 
279
 
            info_dialog(_i18n('Revert successful'),
 
280
 
                        _i18n('Selected file reverted to last revision.'))
 
281
 
        self.app.refresh_right()       
 
283
209
    def commit(self, action):
 
284
210
        """ Right context menu -> Commit """
 
285
 
        from bzrlib.plugins.gtk.commit import CommitDialog
 
 
211
        from commit import CommitDialog
 
288
214
            wt, path = WorkingTree.open_containing(self.path)
 
289
215
            branch = wt.branch
 
290
216
        except NotBranchError, e:
 
294
 
            selected = os.path.join(path, self.selected)
 
297
 
        commit = CommitDialog(wt=wt, selected=selected, parent=None)
 
298
 
        response = commit.run()
 
299
 
        if response != gtk.RESPONSE_NONE:
 
302
 
            if response == gtk.RESPONSE_OK:
 
303
 
                self.app.refresh_right()
 
 
218
        commit = CommitDialog(wt, path, not branch)
 
308
221
    def diff(self, action):
 
309
222
        """ Right context menu -> Diff """
 
310
 
        wt = WorkingTree.open_containing(self.path)[0]
 
311
 
        window = DiffWindow(self.app)
 
 
224
            wt = WorkingTree.open_containing(self.path)[0]
 
 
225
        except errors.NotBranchError:
 
 
226
            error_dialog(_('File is not in a branch'),
 
 
227
                         _('The selected file is not in a branch.'))
 
 
230
        window = DiffWindow()
 
312
231
        parent_tree = wt.branch.repository.revision_tree(wt.branch.last_revision())
 
313
 
        window.set_diff(wt.branch._get_nick(local=True), wt, parent_tree)
 
314
 
        window.set_file(wt.relpath(self.path + os.sep + self.selected))
 
 
232
        window.set_diff(wt.branch.nick, wt, parent_tree)
 
 
234
            window.set_file(wt.relpath(self.path + os.sep + self.selected))
 
 
235
        except errors.NoSuchFile:
 
317
239
    def bookmark(self, action):
 
318
240
        """ Right context menu -> Bookmark """
 
319
241
        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.'))
 
 
242
            info_dialog(_('Bookmark successfully added'),
 
 
243
                        _('The current directory was bookmarked. You can reach\nit by selecting it from the left panel.'))
 
322
244
            self.pref.write()
 
324
 
            warning_dialog(_i18n('Location already bookmarked'),
 
325
 
                           _i18n('The current directory is already bookmarked.\nSee the left panel for reference.'))
 
 
246
            warning_dialog(_('Location already bookmarked'),
 
 
247
                           _('The current directory is already bookmarked.\nSee the left panel for reference.'))
 
327
249
        self.app.refresh_left()
 
329
251
    def edit_bookmark(self, action):
 
330
252
        """ Left context menu -> Edit """
 
331
 
        from bookmark import BookmarkDialog
 
 
253
        from bookmark import OliveBookmarkDialog
 
333
255
        if self.selected != None:
 
334
 
            bookmark = BookmarkDialog(self.selected, self.app.window)
 
 
256
            bookmark = OliveBookmarkDialog(self.selected, self.app.window)
 
335
257
            response = bookmark.run()
 
337
259
            if response != gtk.RESPONSE_NONE:
 
 
365
287
    def diff_all(self, action):
 
366
288
        """ Diff toolbutton -> All... """
 
367
 
        wt = WorkingTree.open_containing(self.path)[0]
 
368
 
        window = DiffWindow(self.app)
 
369
 
        parent_tree = wt.branch.repository.revision_tree(wt.branch.last_revision())
 
370
 
        window.set_diff(wt.branch._get_nick(local=True), wt, parent_tree)
 
373
 
    def view_remote(self, action):
 
374
 
        """ Remote context menu -> View contents """
 
375
 
        print "DEBUG: view contents."
 
377
 
    def diff_remote(self, action):
 
378
 
        """ Remote context menu -> Show differences """
 
379
 
        print "DEBUG: show differences."
 
381
 
    def revert_remote(self, action):
 
382
 
        """ Remote context menu -> Revert to this revision """
 
383
 
        print "DEBUG: revert to this revision."
 
 
289
        from diff import OliveDiff
 
 
290
        diff = OliveDiff(self.comm)