28
29
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
37
32
""" Display the Rename dialog and perform the needed actions. """
38
def __init__(self, wt, wtpath, selected=[]):
33
def __init__(self, comm):
39
34
""" Initialize the Rename dialog. """
40
self.glade = gtk.glade.XML(GLADEFILENAME, 'window_rename')
35
self.glade = gtk.glade.XML(gladefile, 'window_rename')
37
# Communication object
42
40
self.window = self.glade.get_widget('window_rename')
43
self.entry = self.glade.get_widget('entry_rename')
45
42
# Dictionary for signal_autoconnect
46
43
dic = { "on_button_rename_rename_clicked": self.rename,
49
46
# Connect the signals to the handlers
50
47
self.glade.signal_autoconnect(dic)
54
self.selected = selected
57
50
""" Display the Rename dialog. """
58
if self.selected is not None:
59
self.entry.set_text(self.selected)
61
51
self.window.show_all()
64
53
def rename(self, widget):
66
old_filename = self.selected
67
new_filename = self.entry.get_text()
55
entry = self.glade.get_widget('entry_rename')
57
old_filename = self.comm.get_selected_right()
58
new_filename = entry.get_text()
69
60
if old_filename is None:
70
61
error_dialog(_('No file was selected'),
71
_('Please select a file from the list to proceed.'))
62
_('Please select a file from the list to proceed.'))
74
65
if new_filename == "":
75
66
error_dialog(_('Filename not given'),
76
_('Please specify a new name for the file.'))
67
_('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)
70
source = self.comm.get_path() + '/' + old_filename
71
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))
75
wt1, path1 = WorkingTree.open_containing(source)
76
wt2, path2 = WorkingTree.open_containing(source)
86
if wt1.basedir != wt2.basedir:
87
error_dialog(_('Not the same branch'),
88
_('The destination is not in the same branch.'))
78
if wt1.base != wt2.base:
79
error_dialog(_('Not the same branch'),
80
_('The destination is not in the same branch.'))
82
wt1.rename_one(source, destination)
83
except errors.NotBranchError:
84
error_dialog(_('File is not in a branch'),
85
_('The selected file is not in a branch.'))
90
wt1.rename_one(source, destination)
89
self.comm.refresh_right()
93
91
def close(self, widget=None):
94
92
self.window.destroy()