15
15
# Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
21
22
pygtk.require("2.0")
28
import bzrlib.errors as errors
29
from bzrlib.workingtree import WorkingTree
31
from errors import show_bzr_error
32
from bzrlib.plugins.gtk.dialog import error_dialog
33
from guifiles import GLADEFILENAME
31
import olive.backend.errors as errors
32
import olive.backend.fileops as fileops
37
35
""" Display the Rename dialog and perform the needed actions. """
38
def __init__(self, wt, wtpath, selected=[]):
36
def __init__(self, gladefile, comm, dialog):
39
37
""" Initialize the Rename dialog. """
40
self.glade = gtk.glade.XML(GLADEFILENAME, 'window_rename')
38
self.gladefile = gladefile
39
self.glade = gtk.glade.XML(self.gladefile, 'window_rename')
41
# Communication object
42
46
self.window = self.glade.get_widget('window_rename')
43
self.entry = self.glade.get_widget('entry_rename')
45
48
# Dictionary for signal_autoconnect
46
49
dic = { "on_button_rename_rename_clicked": self.rename,
49
52
# Connect the signals to the handlers
50
53
self.glade.signal_autoconnect(dic)
54
self.selected = selected
57
56
""" Display the Rename dialog. """
58
if self.selected is not None:
59
self.entry.set_text(self.selected)
61
57
self.window.show_all()
64
59
def rename(self, widget):
66
old_filename = self.selected
67
new_filename = self.entry.get_text()
61
entry = self.glade.get_widget('entry_rename')
63
old_filename = self.comm.get_selected_right()
64
new_filename = entry.get_text()
69
66
if old_filename is None:
70
error_dialog(_('No file was selected'),
71
_('Please select a file from the list to proceed.'))
67
self.dialog.error_dialog(_('No file was selected'),
68
_('Please select a file from the list to proceed.'))
74
71
if new_filename == "":
75
error_dialog(_('Filename not given'),
76
_('Please specify a new name for the file.'))
72
self.dialog.error_dialog(_('Filename not given'),
73
_('Please specify a new name for the file.'))
79
source = os.path.join(self.wtpath, old_filename)
80
destination = os.path.join(self.wtpath, new_filename)
76
source = self.comm.get_path() + '/' + old_filename
77
destination = self.comm.get_path() + '/' + new_filename
83
wt1, path1 = WorkingTree.open_containing(self.wt.abspath(source))
84
wt2, path2 = WorkingTree.open_containing(self.wt.abspath(source))
81
fileops.rename(source, destination)
82
except errors.NotBranchError:
83
self.dialog.error_dialog(_('File is not in a branch'),
84
_('The selected file is not in a branch.'))
86
except errors.NotSameBranchError:
87
self.dialog.error_dialog(_('Not the same branch'),
88
_('The destination is not in the same branch.'))
86
if wt1.basedir != wt2.basedir:
87
error_dialog(_('Not the same branch'),
88
_('The destination is not in the same branch.'))
90
wt1.rename_one(source, destination)
94
self.comm.refresh_right()
93
96
def close(self, widget=None):
94
97
self.window.destroy()