14
14
# along with this program; if not, write to the Free Software
15
15
# Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
21
21
pygtk.require("2.0")
30
28
import bzrlib.errors as errors
31
from bzrlib.workingtree import WorkingTree
30
from olive import gladefile
31
from dialog import error_dialog, warning_dialog
34
34
""" Display the Remove file(s) dialog and perform the needed actions. """
35
def __init__(self, gladefile, comm, dialog):
35
def __init__(self, wt, wtpath, selected=[]):
36
36
""" Initialize the Remove file(s) dialog. """
37
self.gladefile = gladefile
38
self.glade = gtk.glade.XML(self.gladefile, 'window_remove')
40
# Communication object
37
self.glade = gtk.glade.XML(gladefile, 'window_remove')
45
39
self.window = self.glade.get_widget('window_remove')
59
57
radio_selected = self.glade.get_widget('radiobutton_remove_selected')
60
58
radio_new = self.glade.get_widget('radiobutton_remove_new')
62
directory = self.comm.get_path()
64
self.comm.set_busy(self.window)
65
60
if radio_selected.get_active():
66
61
# Remove only the selected file
67
filename = self.comm.get_selected_right()
62
filename = self.selected
69
64
if filename is None:
70
self.dialog.error_dialog(_('No file was selected'),
71
_('Please select a file from the list,\nor choose the other option.'))
72
self.comm.set_busy(self.window, False)
65
error_dialog(_('No file was selected'),
66
_('Please select a file from the list,\nor choose the other option.'))
69
fullpath = self.wt.abspath(os.path.join(self.wtpath, filename))
76
wt, path = WorkingTree.open_containing(directory + os.sep + filename)
72
self.wt.remove(fullpath)
78
73
except errors.NotBranchError:
79
self.dialog.error_dialog(_('Directory is not a branch'),
80
_('You can perform this action only in a branch.'))
81
self.comm.set_busy(self.window, False)
74
error_dialog(_('Directory is not a branch'),
75
_('You can perform this action only in a branch.'))
83
77
except errors.NotVersionedError:
84
self.dialog.error_dialog(_('File not versioned'),
85
_('The selected file is not versioned.'))
86
self.comm.set_busy(self.window, False)
78
error_dialog(_('File not versioned'),
79
_('The selected file is not versioned.'))
90
81
elif radio_new.get_active():
91
82
# Remove added files recursively
93
wt, path = WorkingTree.open_containing(directory)
94
except errors.NotBranchError:
95
self.dialog.error_dialog(_('Directory is not a branch'),
96
_('You can perform this action only in a branch.'))
97
self.comm.set_busy(self.window, False)
102
added = wt.changes_from(wt.basis_tree()).added
83
added = self.wt.changes_from(self.wt.basis_tree()).added
103
84
file_list = sorted([f[0] for f in added], reverse=True)
104
85
if len(file_list) == 0:
105
dialog.warning_dialog(_('No matching files'),
106
_('No added files were found in the working tree.'))
107
self.comm.set_busy(self.window, False)
86
warning_dialog(_('No matching files'),
87
_('No added files were found in the working tree.'))
111
# This should really never happen.
89
self.wt.remove(file_list)
115
self.comm.refresh_right()
117
93
def close(self, widget=None):
118
94
self.window.destroy()