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
42
36
""" This class is responsible for building the context menus. """
43
def __init__(self, path, selected, app=None):
37
def __init__(self, path, selected):
45
from guifiles import UIFILENAME
47
self.uifile = UIFILENAME
39
if sys.platform == 'win32':
40
self.uifile = os.path.dirname(sys.executable) + "/share/olive/cmenu.ui"
42
self.uifile = "/usr/share/olive/cmenu.ui"
44
if not os.path.exists(self.uifile):
45
# Load from current directory if not installed
46
self.uifile = "cmenu.ui"
48
if not os.path.exists(self.uifile):
50
print _('UI description file cannot be found.')
49
53
# Preferences handler
50
self.pref = Preferences()
54
self.pref = OlivePreferences()
52
56
# Set default values
54
58
self.selected = selected
57
60
# Create the file list context menu
58
61
self.ui = gtk.UIManager()
60
63
self.actiongroup = gtk.ActionGroup('context')
61
64
self.actiongroup.add_actions([('add', gtk.STOCK_ADD,
63
_i18n('Add the selected file'),
66
_('Add the selected file'),
65
68
('remove', gtk.STOCK_REMOVE,
66
_i18n('Remove'), None,
67
_i18n('Remove the selected file'),
70
_('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'),
77
72
('open', gtk.STOCK_OPEN,
79
_i18n('Open the selected file'),
74
_('Open the selected file'),
82
_i18n('Revert'), None,
83
_i18n('Revert the changes'),
86
_i18n('Commit'), None,
87
_i18n('Commit the changes'),
78
_('Commit the changes'),
90
_i18n('Annotate'), None,
91
_i18n('Annotate the selected file'),
95
_i18n('Show the diff of the file'),
82
_('Show the diff of the file'),
98
_i18n('Bookmark'), None,
99
_i18n('Bookmark current location'),
86
_('Bookmark current location'),
101
88
('edit_bookmark', gtk.STOCK_EDIT,
103
_i18n('Edit the selected bookmark'),
90
_('Edit the selected bookmark'),
104
91
self.edit_bookmark),
105
92
('remove_bookmark', gtk.STOCK_REMOVE,
106
_i18n('Remove'), None,
107
_i18n('Remove the selected bookmark'),
94
_('Remove the selected bookmark'),
108
95
self.remove_bookmark),
109
96
('open_folder', gtk.STOCK_OPEN,
110
_i18n('Open Folder'), None,
111
_i18n('Open bookmark folder in Nautilus'),
97
_('Open Folder'), None,
98
_('Open bookmark folder in Nautilus'),
112
99
self.open_folder),
113
100
('diff_selected', None,
114
_i18n('Selected...'), None,
115
_i18n('Show the differences of the selected file'),
101
_('Selected...'), None,
102
_('Show the differences of the selected file'),
116
103
self.diff_selected),
117
104
('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'),
106
_('Show the differences of all files'),
135
110
self.ui.insert_action_group(self.actiongroup, 0)
174
144
filename = self.selected
176
146
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)
147
error_dialog(_('No file was selected'),
148
_('Please select a file from the list,\nor choose the other option.'))
209
window.annotate(wt, branch, file_id)
152
bzrlib.add.smart_add([directory + '/' + filename])
153
except errors.NotBranchError:
154
error_dialog(_('Directory is not a branch'),
155
_('You can perform this action only in a branch.'))
214
def remove_file(self, action, delete_on_disk=False):
158
def remove_file(self, action):
215
159
""" Right context menu -> Remove """
216
160
# Remove only the selected file
217
161
directory = self.path
218
162
filename = self.selected
220
164
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)
237
self.app.set_path(self.path)
238
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
def rename_file(self, action):
245
""" 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()
165
error_dialog(_('No file was selected'),
166
_('Please select a file from the list,\nor choose the other option.'))
170
wt, path = WorkingTree.open_containing(directory + os.sep + filename)
173
except errors.NotBranchError:
174
error_dialog(_('Directory is not a branch'),
175
_('You can perform this action only in a branch.'))
177
except errors.NotVersionedError:
178
error_dialog(_('File not versioned'),
179
_('The selected file is not versioned.'))
254
182
def open_file(self, action):
255
183
""" Right context menu -> Open """
256
184
# Open only the selected file
257
185
filename = self.selected
259
187
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.'))
188
error_dialog(_('No file was selected'),
189
_('Please select a file from the list,\nor choose the other option.'))
264
192
if filename == '..':
265
193
# TODO: how to enter a directory?
268
fullpath = os.path.join(self.path, filename)
269
launch.launch(fullpath)
196
fullpath = self.path + os.sep + filename
197
if os.path.isdir(fullpath):
198
# selected item is an existant directory
199
# 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
204
def commit(self, action):
284
205
""" Right context menu -> Commit """
285
from commit import CommitDialog
288
wt, path = WorkingTree.open_containing(self.path)
290
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()
206
from commit import OliveCommit
207
wt, path = WorkingTree.open_containing(self.path)
208
commit = OliveCommit(wt, path)
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)
213
from bzrlib.plugins.gtk.viz.diffwin import DiffWindow
216
wt = WorkingTree.open_containing(self.path)[0]
217
except errors.NotBranchError:
218
error_dialog(_('File is not in a branch'),
219
_('The selected file is not in a branch.'))
222
window = DiffWindow()
312
223
parent_tree = wt.branch.repository.revision_tree(wt.branch.last_revision())
313
224
window.set_diff(wt.branch.nick, wt, parent_tree)
314
window.set_file(wt.relpath(self.path + os.sep + self.selected))
317
227
def bookmark(self, action):
318
228
""" Right context menu -> Bookmark """
319
229
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.'))
230
info_dialog(_('Bookmark successfully added'),
231
_('The current directory was bookmarked. You can reach\nit by selecting it from the left panel.'))
322
232
self.pref.write()
324
warning_dialog(_i18n('Location already bookmarked'),
325
_i18n('The current directory is already bookmarked.\nSee the left panel for reference.'))
327
self.app.refresh_left()
234
warning_dialog(_('Location already bookmarked'),
235
_('The current directory is already bookmarked.\nSee the left panel for reference.'))
329
237
def edit_bookmark(self, action):
330
238
""" Left context menu -> Edit """
331
from bookmark import BookmarkDialog
239
from bookmark import OliveBookmark
333
241
if self.selected != None:
334
bookmark = BookmarkDialog(self.selected, self.app.window)
335
response = bookmark.run()
337
if response != gtk.RESPONSE_NONE:
340
if response == gtk.RESPONSE_OK:
341
self.app.refresh_left()
242
bookmark = OliveBookmark(self.selected)
345
245
def remove_bookmark(self, action):
346
246
""" Left context menu -> Remove """
348
248
if self.selected != None:
349
self.pref.remove_bookmark(self.selected)
352
self.app.refresh_left()
249
self.pref.remove_bookmark(self.comm.get_selected_left())
250
self.comm.refresh_left()
354
252
def open_folder(self, action):
355
253
""" Left context menu -> Open Folder """
356
254
path = self.selected
361
259
def diff_selected(self, action):
362
260
""" Diff toolbutton -> Selected... """