104
138
self.cmenu_right = self.ui.get_widget('/context_right')
105
139
self.cmenu_left = self.ui.get_widget('/context_left')
106
140
self.toolbar_diff = self.ui.get_widget('/toolbar_diff')
141
self.cmenu_remote = self.ui.get_widget('/context_remote')
109
commit_menu = self.ui.get_widget('/context_right/commit')
110
commit_image = self.comm.menuitem_branch_commit.get_image()
111
commit_pixbuf = commit_image.get_pixbuf()
112
commit_icon = gtk.Image()
113
commit_icon.set_from_pixbuf(commit_pixbuf)
114
commit_menu.set_image(commit_icon)
115
diff_menu = self.ui.get_widget('/context_right/diff')
116
diff_image = self.comm.menuitem_stats_diff.get_image()
117
diff_pixbuf = diff_image.get_pixbuf()
118
diff_icon = gtk.Image()
119
diff_icon.set_from_pixbuf(diff_pixbuf)
120
diff_menu.set_image(diff_icon)
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)
122
158
def right_context_menu(self):
123
159
return self.cmenu_right
125
161
def left_context_menu(self):
126
162
return self.cmenu_left
164
def remote_context_menu(self):
165
return self.cmenu_remote
128
168
def add_file(self, action):
129
169
""" Right context menu -> Add """
130
172
# Add only the selected file
131
directory = self.comm.get_path()
132
filename = self.comm.get_selected_right()
173
directory = self.path
174
filename = self.selected
134
176
if filename is None:
135
177
error_dialog(_('No file was selected'),
136
178
_('Please select a file from the list,\nor choose the other option.'))
181
bzrlib.add.smart_add([os.path.join(directory, filename)])
184
def annotate(self, action):
185
""" Right context menu -> Annotate """
186
directory = self.path
187
filename = self.selected
190
error_dialog(_('No file was selected'),
191
_('Please select a file from the list.'))
194
wt, path = WorkingTree.open_containing(os.path.join(directory, filename))
197
file_id = wt.path2id(wt.relpath(os.path.join(directory, filename)))
199
window = GAnnotateWindow(all=False, plain=False, parent=self.app)
200
window.set_title(os.path.join(directory, filename) + " - Annotate")
201
config = GAnnotateConfig(window)
140
bzrlib.add.smart_add([directory + '/' + filename])
141
except errors.NotBranchError:
142
error_dialog(_('Directory is not a branch'),
143
_('You can perform this action only in a branch.'))
146
self.comm.refresh_right()
205
window.annotate(wt, branch, file_id)
148
def remove_file(self, action):
210
def remove_file(self, action,delete_on_disk=0):
149
211
""" Right context menu -> Remove """
150
212
# Remove only the selected file
151
directory = self.comm.get_path()
152
filename = self.comm.get_selected_right()
213
directory = self.path
214
filename = self.selected
154
216
if filename is None:
155
217
error_dialog(_('No file was selected'),
156
218
_('Please select a file from the list,\nor choose the other option.'))
160
wt, path = WorkingTree.open_containing(directory+'/'+filename)
163
except errors.NotBranchError:
164
error_dialog(_('Directory is not a branch'),
165
_('You can perform this action only in a branch.'))
167
except errors.NotVersionedError:
168
error_dialog(_('File not versioned'),
169
_('The selected file is not versioned.'))
172
self.comm.refresh_right()
221
wt, path = WorkingTree.open_containing(os.path.join(directory, filename))
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)
231
os.remove(abs_filename)
233
self.app.set_path(self.path)
234
self.app.refresh_right()
236
def remove_and_delete_file(self, action):
237
""" Right context menu -> Remove and delete"""
238
self.remove_file(action,delete_on_disk=1)
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)
174
247
def open_file(self, action):
175
248
""" Right context menu -> Open """
176
249
# Open only the selected file
177
filename = self.comm.get_selected_right()
250
filename = self.selected
179
252
if filename is None:
180
253
error_dialog(_('No file was selected'),
181
_('Please select a file from the list,\nor choose the other option.'))
254
_('Please select a file from the list,\nor choose the other option.'))
184
257
if filename == '..':
185
self.comm.set_path(os.path.split(self.comm.get_path())[0])
258
# TODO: how to enter a directory?
187
fullpath = self.comm.get_path() + os.sep + filename
261
fullpath = self.path + os.sep + filename
188
262
if os.path.isdir(fullpath):
189
263
# selected item is an existant directory
190
self.comm.set_path(fullpath)
264
# TODO: how to enter a directory?
194
self.comm.refresh_right()
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)])
274
warning_dialog(_('Conflicts detected'),
275
_('Please have a look at the working tree before continuing.'))
277
info_dialog(_('Revert successful'),
278
_('All files reverted to last revision.'))
279
self.app.refresh_right()
196
281
def commit(self, action):
197
282
""" Right context menu -> Commit """
198
from commit import OliveCommit
199
wt, path = WorkingTree.open_containing(self.comm.get_path())
200
commit = OliveCommit(wt, path)
283
from commit import CommitDialog
286
wt, path = WorkingTree.open_containing(self.path)
288
except NotBranchError, e:
292
selected = os.path.join(path, self.selected)
295
commit = CommitDialog(wt=wt, selected=selected, parent=None)
296
response = commit.run()
297
if response != gtk.RESPONSE_NONE:
300
if response == gtk.RESPONSE_OK:
301
self.app.refresh_right()
203
306
def diff(self, action):
204
307
""" Right context menu -> Diff """
205
from diff import OliveDiff
206
diff = OliveDiff(self.comm)
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))
209
315
def bookmark(self, action):
210
316
""" Right context menu -> Bookmark """
211
if self.comm.pref.add_bookmark(self.comm.get_path()):
317
if self.pref.add_bookmark(self.path):
212
318
info_dialog(_('Bookmark successfully added'),
213
_('The current directory was bookmarked. You can reach\nit by selecting it from the left panel.'))
319
_('The current directory was bookmarked. You can reach\nit by selecting it from the left panel.'))
215
322
warning_dialog(_('Location already bookmarked'),
216
_('The current directory is already bookmarked.\nSee the left panel for reference.'))
323
_('The current directory is already bookmarked.\nSee the left panel for reference.'))
218
self.comm.refresh_left()
325
self.app.refresh_left()
220
327
def edit_bookmark(self, action):
221
328
""" Left context menu -> Edit """
222
from bookmark import OliveBookmark
224
if self.comm.get_selected_left() != None:
225
bookmark = OliveBookmark(self.comm)
329
from bookmark import BookmarkDialog
331
if self.selected != None:
332
bookmark = BookmarkDialog(self.selected, self.app.window)
333
response = bookmark.run()
335
if response != gtk.RESPONSE_NONE:
338
if response == gtk.RESPONSE_OK:
339
self.app.refresh_left()
228
343
def remove_bookmark(self, action):
229
344
""" Left context menu -> Remove """
231
if self.comm.get_selected_left() != None:
232
self.comm.pref.remove_bookmark(self.comm.get_selected_left())
233
self.comm.refresh_left()
346
if self.selected != None:
347
self.pref.remove_bookmark(self.selected)
350
self.app.refresh_left()
235
352
def open_folder(self, action):
236
353
""" Left context menu -> Open Folder """
237
path = self.comm.get_selected_left()