70
72
commit = OliveCommit(self.gladefile, self.comm, self.dialog)
75
def on_menuitem_branch_missing_revisions_activate(self, widget):
76
""" Branch/Missing revisions menu handler. """
78
self.comm.set_busy(self.comm.window_main)
84
local_branch = Branch.open_containing(self.comm.get_path())[0]
85
except NotBranchError:
86
self.dialog.error_dialog(_('Directory is not a branch'),
87
_('You can perform this action only in a branch.'))
90
other_branch = local_branch.get_parent()
91
if other_branch is None:
92
self.dialog.error_dialog(_('Parent location is unknown'),
93
_('Cannot determine missing revisions if no parent location is known.'))
96
remote_branch = Branch.open(other_branch)
98
if remote_branch.base == local_branch.base:
99
remote_branch = local_branch
101
ret = len(local_branch.missing_revisions(remote_branch))
104
self.dialog.info_dialog(_('There are missing revisions'),
105
_('%d revision(s) missing.') % ret)
107
self.dialog.info_dialog(_('Local branch up to date'),
108
_('There are no missing revisions.'))
110
self.comm.set_busy(self.comm.window_main, False)
73
112
def on_menuitem_branch_pull_activate(self, widget):
74
113
""" Branch/Pull menu handler. """
75
import olive.backend.update as update
77
115
self.comm.set_busy(self.comm.window_main)
80
ret = update.pull(self.comm.get_path())
81
except errors.NotBranchError:
82
self.dialog.error_dialog(_('Directory is not a branch'),
83
_('You can perform this action only in a branch.'))
84
except errors.NoLocationKnown:
85
self.dialog.error_dialog(_('Parent location is unknown'),
86
_('Pulling is not possible until there is no parent location.'))
119
from bzrlib.workingtree import WorkingTree
120
tree_to = WorkingTree.open_containing(self.comm.get_path())[0]
121
branch_to = tree_to.branch
122
except errors.NoWorkingTree:
124
branch_to = Branch.open_containing(self.comm.get_path())[0]
125
except errors.NotBranchError:
126
self.dialog.error_dialog(_('Directory is not a branch'),
127
_('You can perform this action only in a branch.'))
129
location = branch_to.get_parent()
131
self.dialog.error_dialog(_('Parent location is unknown'),
132
_('Pulling is not possible until there is a parent location.'))
136
branch_from = Branch.open(location)
137
except errors.NotBranchError:
138
self.dialog.error_dialog(_('Directory is not a branch'),
139
_('You can perform this action only in a branch.'))
141
if branch_to.get_parent() is None:
142
branch_to.set_parent(branch_from.base)
144
old_rh = branch_to.revision_history()
145
if tree_to is not None:
146
tree_to.pull(branch_from)
148
branch_to.pull(branch_from)
88
150
self.dialog.info_dialog(_('Pull successful'),
89
151
_('%d revision(s) pulled.') % ret)
91
self.comm.set_busy(self.comm.window_main, False)
154
self.comm.set_busy(self.comm.window_main, False)
93
156
def on_menuitem_branch_push_activate(self, widget):
94
157
""" Branch/Push... menu handler. """
105
168
def on_menuitem_branch_initialize_activate(self, widget):
106
169
""" Initialize current directory. """
107
import olive.backend.init as init
110
init.init(self.comm.get_path())
171
location = self.comm.get_path()
172
from bzrlib.builtins import get_format_type
174
format = get_format_type('default')
176
if not os.path.exists(location):
180
existing_bzrdir = bzrdir.BzrDir.open(location)
181
except NotBranchError:
182
bzrdir.BzrDir.create_branch_convenience(location, format=format)
184
if existing_bzrdir.has_branch():
185
if existing_bzrdir.has_workingtree():
186
raise AlreadyBranchError(location)
188
raise BranchExistsWithoutWorkingTree(location)
190
existing_bzrdir.create_branch()
191
existing_bzrdir.create_workingtree()
111
192
except errors.AlreadyBranchError, errmsg:
112
193
self.dialog.error_dialog(_('Directory is already a branch'),
113
194
_('The current directory (%s) is already a branch.\nYou can start using it, or initialize another directory.') % errmsg)
114
195
except errors.BranchExistsWithoutWorkingTree, errmsg:
115
196
self.dialog.error_dialog(_('Branch without a working tree'),
116
197
_('The current directory (%s)\nis a branch without a working tree.') % errmsg)
120
self.dialog.info_dialog(_('Ininialize successful'),
199
self.dialog.info_dialog(_('Initialize successful'),
121
200
_('Directory successfully initialized.'))
122
201
self.comm.refresh_right()
186
265
def on_treeview_left_button_press_event(self, widget, event):
187
266
""" Occurs when somebody right-clicks in the bookmark list. """
188
267
if event.button == 3:
268
# Don't show context with nothing selected
269
if self.comm.get_selected_left() == None:
189
272
self.menu.left_context_menu().popup(None, None, None, 0,
192
275
def on_treeview_left_row_activated(self, treeview, path, view_column):
193
276
""" Occurs when somebody double-clicks or enters an item in the
194
277
bookmark list. """
279
newdir = self.comm.get_selected_left()
195
283
self.comm.set_busy(treeview)
197
newdir = self.comm.get_selected_left()
198
284
self.comm.set_path(newdir)
200
285
self.comm.refresh_right()
202
286
self.comm.set_busy(treeview, False)
204
288
def on_treeview_right_button_press_event(self, widget, event):
210
294
m_commit = self.menu.ui.get_widget('/context_right/commit')
211
295
m_diff = self.menu.ui.get_widget('/context_right/diff')
212
296
# check if we're in a branch
213
if not is_branch(self.comm.get_path()):
298
from bzrlib.branch import Branch
299
Branch.open_containing(self.comm.get_path())
300
m_add.set_sensitive(True)
301
m_remove.set_sensitive(True)
302
m_commit.set_sensitive(True)
303
m_diff.set_sensitive(True)
304
except errors.NotBranchError:
214
305
m_add.set_sensitive(False)
215
306
m_remove.set_sensitive(False)
216
307
m_commit.set_sensitive(False)
217
308
m_diff.set_sensitive(False)
219
m_add.set_sensitive(True)
220
m_remove.set_sensitive(True)
221
m_commit.set_sensitive(True)
222
m_diff.set_sensitive(True)
223
309
self.menu.right_context_menu().popup(None, None, None, 0,
233
319
if newdir == '..':
234
320
self.comm.set_path(os.path.split(self.comm.get_path())[0])
236
fullpath = self.comm.get_path() + '/' + newdir
322
fullpath = self.comm.get_path() + os.sep + newdir
237
323
if os.path.isdir(fullpath):
238
324
# selected item is an existant directory
239
325
self.comm.set_path(fullpath)
241
if sys.platform == 'win32':
242
# open the file with the default application
243
os.startfile(fullpath)
245
# TODO: support other OSes
246
print "DEBUG: double-click on non-Win32 platforms not supported."
248
329
self.comm.refresh_right()