106
139
self.cmenu_right = self.ui.get_widget('/context_right')
107
140
self.cmenu_left = self.ui.get_widget('/context_left')
108
141
self.toolbar_diff = self.ui.get_widget('/toolbar_diff')
142
self.cmenu_remote = self.ui.get_widget('/context_remote')
111
commit_menu = self.ui.get_widget('/context_right/commit')
112
commit_image = self.comm.menuitem_branch_commit.get_image()
113
commit_pixbuf = commit_image.get_pixbuf()
114
commit_icon = gtk.Image()
115
commit_icon.set_from_pixbuf(commit_pixbuf)
116
commit_menu.set_image(commit_icon)
117
diff_menu = self.ui.get_widget('/context_right/diff')
118
diff_image = self.comm.menuitem_stats_diff.get_image()
119
diff_pixbuf = diff_image.get_pixbuf()
120
diff_icon = gtk.Image()
121
diff_icon.set_from_pixbuf(diff_pixbuf)
122
diff_menu.set_image(diff_icon)
145
# TODO: do it without using deprecated comm
146
#commit_menu = self.ui.get_widget('/context_right/commit')
147
#commit_image = self.comm.menuitem_branch_commit.get_image()
148
#commit_pixbuf = commit_image.get_pixbuf()
149
#commit_icon = gtk.Image()
150
#commit_icon.set_from_pixbuf(commit_pixbuf)
151
#commit_menu.set_image(commit_icon)
152
#diff_menu = self.ui.get_widget('/context_right/diff')
153
#diff_image = self.comm.menuitem_stats_diff.get_image()
154
#diff_pixbuf = diff_image.get_pixbuf()
155
#diff_icon = gtk.Image()
156
#diff_icon.set_from_pixbuf(diff_pixbuf)
157
#diff_menu.set_image(diff_icon)
124
159
def right_context_menu(self):
125
160
return self.cmenu_right
127
162
def left_context_menu(self):
128
163
return self.cmenu_left
165
def remote_context_menu(self):
166
return self.cmenu_remote
130
169
def add_file(self, action):
131
170
""" Right context menu -> Add """
132
173
# Add only the selected file
133
directory = self.comm.get_path()
134
filename = self.comm.get_selected_right()
174
directory = self.path
175
filename = self.selected
136
177
if filename is None:
137
178
error_dialog(_('No file was selected'),
138
_('Please select a file from the list,\nor choose the other option.'))
179
_('Please select a file from the list,\nor choose the other option.'))
182
bzrlib.add.smart_add([os.path.join(directory, filename)])
185
def annotate(self, action):
186
""" Right context menu -> Annotate """
187
directory = self.path
188
filename = self.selected
191
error_dialog(_('No file was selected'),
192
_('Please select a file from the list.'))
195
wt, path = WorkingTree.open_containing(os.path.join(directory, filename))
198
file_id = wt.path2id(wt.relpath(os.path.join(directory, filename)))
200
window = GAnnotateWindow(all=False, plain=False)
201
window.set_title(os.path.join(directory, filename) + " - Annotate")
202
config = GAnnotateConfig(window)
142
bzrlib.add.smart_add([directory + '/' + filename])
143
except errors.NotBranchError:
144
error_dialog(_('Directory is not a branch'),
145
_('You can perform this action only in a branch.'))
148
self.comm.refresh_right()
206
window.annotate(wt, branch, file_id)
150
def remove_file(self, action):
211
def remove_file(self, action,delete_on_disk=0):
151
212
""" Right context menu -> Remove """
152
213
# Remove only the selected file
153
directory = self.comm.get_path()
154
filename = self.comm.get_selected_right()
214
directory = self.path
215
filename = self.selected
156
217
if filename is None:
157
218
error_dialog(_('No file was selected'),
158
_('Please select a file from the list,\nor choose the other option.'))
162
wt, path = WorkingTree.open_containing(directory+'/'+filename)
165
except errors.NotBranchError:
166
error_dialog(_('Directory is not a branch'),
167
_('You can perform this action only in a branch.'))
169
except errors.NotVersionedError:
170
error_dialog(_('File not versioned'),
171
_('The selected file is not versioned.'))
176
self.comm.refresh_right()
219
_('Please select a file from the list,\nor choose the other option.'))
222
wt, path = WorkingTree.open_containing(os.path.join(directory, filename))
226
abs_filename = os.path.join(directory,filename)
227
if os.path.isdir(abs_filename):
228
response = question_dialog(_('Delete directory with all directories below ?'), abs_filename )
229
if response == gtk.RESPONSE_YES:
230
shutil.rmtree(abs_filename)
232
os.remove(abs_filename)
234
self.app.set_path(self.path)
235
self.app.refresh_right()
237
def remove_and_delete_file(self, action):
238
""" Right context menu -> Remove and delete"""
239
self.remove_file(action,delete_on_disk=1)
241
def rename_file(self, action):
242
""" Right context menu -> Rename """
243
from rename import OliveRename
244
wt = WorkingTree.open_containing(self.path + os.sep + self.selected)[0]
245
rename = OliveRename(wt, wt.relpath(self.path), self.selected)
178
248
def open_file(self, action):
179
249
""" Right context menu -> Open """
180
250
# Open only the selected file
181
filename = self.comm.get_selected_right()
251
filename = self.selected
183
253
if filename is None:
184
254
error_dialog(_('No file was selected'),
185
_('Please select a file from the list,\nor choose the other option.'))
255
_('Please select a file from the list,\nor choose the other option.'))
188
258
if filename == '..':
189
self.comm.set_path(os.path.split(self.comm.get_path())[0])
259
# TODO: how to enter a directory?
191
fullpath = self.comm.get_path() + os.sep + filename
262
fullpath = self.path + os.sep + filename
192
263
if os.path.isdir(fullpath):
193
264
# selected item is an existant directory
194
self.comm.set_path(fullpath)
265
# TODO: how to enter a directory?
198
self.comm.refresh_right()
270
def revert(self, action):
271
""" Right context menu -> Revert """
272
wt, path = WorkingTree.open_containing(self.path)
273
ret = wt.revert([os.path.join(path, self.selected)])
275
warning_dialog(_('Conflicts detected'),
276
_('Please have a look at the working tree before continuing.'))
278
info_dialog(_('Revert successful'),
279
_('All files reverted to last revision.'))
280
self.app.refresh_right()
200
282
def commit(self, action):
201
283
""" Right context menu -> Commit """
202
from commit import OliveCommit
203
wt, path = WorkingTree.open_containing(self.comm.get_path())
204
commit = OliveCommit(wt, path)
284
from commit import CommitDialog
287
wt, path = WorkingTree.open_containing(self.path)
289
except NotBranchError, e:
292
commit = CommitDialog(wt, path, not branch, self.selected)
293
response = commit.run()
294
if response != gtk.RESPONSE_NONE:
297
if response == gtk.RESPONSE_OK:
298
self.app.refresh_right()
207
303
def diff(self, action):
208
304
""" Right context menu -> Diff """
209
from diff import OliveDiff
210
diff = OliveDiff(self.comm)
305
wt = WorkingTree.open_containing(self.path)[0]
306
window = DiffWindow()
307
parent_tree = wt.branch.repository.revision_tree(wt.branch.last_revision())
308
window.set_diff(wt.branch.nick, wt, parent_tree)
309
window.set_file(wt.relpath(self.path + os.sep + self.selected))
213
312
def bookmark(self, action):
214
313
""" Right context menu -> Bookmark """
215
if self.comm.pref.add_bookmark(self.comm.get_path()):
314
if self.pref.add_bookmark(self.path):
216
315
info_dialog(_('Bookmark successfully added'),
217
_('The current directory was bookmarked. You can reach\nit by selecting it from the left panel.'))
316
_('The current directory was bookmarked. You can reach\nit by selecting it from the left panel.'))
219
319
warning_dialog(_('Location already bookmarked'),
220
_('The current directory is already bookmarked.\nSee the left panel for reference.'))
320
_('The current directory is already bookmarked.\nSee the left panel for reference.'))
222
self.comm.refresh_left()
322
self.app.refresh_left()
224
324
def edit_bookmark(self, action):
225
325
""" Left context menu -> Edit """
226
from bookmark import OliveBookmark
228
if self.comm.get_selected_left() != None:
229
bookmark = OliveBookmark(self.comm)
326
from bookmark import BookmarkDialog
328
if self.selected != None:
329
bookmark = BookmarkDialog(self.selected, self.app.window)
330
response = bookmark.run()
332
if response != gtk.RESPONSE_NONE:
335
if response == gtk.RESPONSE_OK:
336
self.app.refresh_left()
232
340
def remove_bookmark(self, action):
233
341
""" Left context menu -> Remove """
235
if self.comm.get_selected_left() != None:
236
self.comm.pref.remove_bookmark(self.comm.get_selected_left())
237
self.comm.refresh_left()
343
if self.selected != None:
344
self.pref.remove_bookmark(self.selected)
347
self.app.refresh_left()
239
349
def open_folder(self, action):
240
350
""" Left context menu -> Open Folder """
241
path = self.comm.get_selected_left()