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