bzr branch
http://gegoxaren.bato24.eu/bzr/b-gtk/fix-viz
0.8.19
by Szilveszter Farkas (Phanatic)
2006-07-21 Szilveszter Farkas <Szilveszter.Farkas@gmail.com> |
1 |
# Copyright (C) 2006 by Szilveszter Farkas (Phanatic) <szilveszter.farkas@gmail.com>
|
0.8.46
by Szilveszter Farkas (Phanatic)
Modified OliveDialog class interface; huge cleanups. |
2 |
#
|
0.8.19
by Szilveszter Farkas (Phanatic)
2006-07-21 Szilveszter Farkas <Szilveszter.Farkas@gmail.com> |
3 |
# This program is free software; you can redistribute it and/or modify
|
4 |
# it under the terms of the GNU General Public License as published by
|
|
5 |
# the Free Software Foundation; either version 2 of the License, or
|
|
6 |
# (at your option) any later version.
|
|
0.8.46
by Szilveszter Farkas (Phanatic)
Modified OliveDialog class interface; huge cleanups. |
7 |
#
|
0.8.19
by Szilveszter Farkas (Phanatic)
2006-07-21 Szilveszter Farkas <Szilveszter.Farkas@gmail.com> |
8 |
# This program is distributed in the hope that it will be useful,
|
9 |
# but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
10 |
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
11 |
# GNU General Public License for more details.
|
|
0.8.46
by Szilveszter Farkas (Phanatic)
Modified OliveDialog class interface; huge cleanups. |
12 |
#
|
0.8.19
by Szilveszter Farkas (Phanatic)
2006-07-21 Szilveszter Farkas <Szilveszter.Farkas@gmail.com> |
13 |
# You should have received a copy of the GNU General Public License
|
14 |
# along with this program; if not, write to the Free Software
|
|
15 |
# Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
|
|
16 |
||
0.8.93
by Szilveszter Farkas (Phanatic)
Some further cleanups. More to come. |
17 |
import os |
0.8.19
by Szilveszter Farkas (Phanatic)
2006-07-21 Szilveszter Farkas <Szilveszter.Farkas@gmail.com> |
18 |
|
19 |
try: |
|
20 |
import pygtk |
|
21 |
pygtk.require("2.0") |
|
22 |
except: |
|
0.13.11
by Jelmer Vernooij
Bunch of small fixes, cleanups and simplifications. |
23 |
pass
|
24 |
||
0.13.10
by Jelmer Vernooij
Don't pass around gladefile all the time. |
25 |
import gtk |
0.8.19
by Szilveszter Farkas (Phanatic)
2006-07-21 Szilveszter Farkas <Szilveszter.Farkas@gmail.com> |
26 |
|
0.11.1
by Jelmer Vernooij
Eliminate olive.backend.errors. |
27 |
import bzrlib.errors as errors |
0.8.19
by Szilveszter Farkas (Phanatic)
2006-07-21 Szilveszter Farkas <Szilveszter.Farkas@gmail.com> |
28 |
|
475.1.2
by Vincent Ladeuil
Fix bug #187283 fix replacing _() by _i18n(). |
29 |
from bzrlib.plugins.gtk import _i18n |
151
by Jelmer Vernooij
Move dialog to top-level directory. |
30 |
from bzrlib.plugins.gtk.dialog import error_dialog, warning_dialog |
533.5.1
by Jasper Groenewegen
Remove glade bits of OliveRemove, tweak existing (Olive)RemoveDialog |
31 |
from bzrlib.plugins.gtk.errors import show_bzr_error |
32 |
||
33 |
||
34 |
class RemoveDialog(gtk.Dialog): |
|
120
by Szilveszter Farkas (Phanatic)
Use OliveRemoveDialog class instead of OliveRemove. |
35 |
""" This class wraps the old Remove window into a gtk.Dialog. """ |
36 |
||
533.5.1
by Jasper Groenewegen
Remove glade bits of OliveRemove, tweak existing (Olive)RemoveDialog |
37 |
def __init__(self, wt, wtpath, selected='', parent=None): |
120
by Szilveszter Farkas (Phanatic)
Use OliveRemoveDialog class instead of OliveRemove. |
38 |
""" Initialize the Remove file(s) dialog. """ |
533.5.1
by Jasper Groenewegen
Remove glade bits of OliveRemove, tweak existing (Olive)RemoveDialog |
39 |
gtk.Dialog.__init__(self, title="Olive - Remove files", |
120
by Szilveszter Farkas (Phanatic)
Use OliveRemoveDialog class instead of OliveRemove. |
40 |
parent=parent, |
41 |
flags=0, |
|
42 |
buttons=(gtk.STOCK_CANCEL, gtk.RESPONSE_CANCEL)) |
|
43 |
||
44 |
# Get arguments
|
|
45 |
self.wt = wt |
|
46 |
self.wtpath = wtpath |
|
47 |
self.selected = selected |
|
48 |
||
49 |
# Create widgets
|
|
475.1.2
by Vincent Ladeuil
Fix bug #187283 fix replacing _() by _i18n(). |
50 |
self._label = gtk.Label(_i18n("Which file(s) do you want to remove?")) |
533.5.1
by Jasper Groenewegen
Remove glade bits of OliveRemove, tweak existing (Olive)RemoveDialog |
51 |
self._radio_selected = gtk.RadioButton(None, _i18n("Selected: %s"%self.selected), False) |
475.1.2
by Vincent Ladeuil
Fix bug #187283 fix replacing _() by _i18n(). |
52 |
self._radio_added = gtk.RadioButton(self._radio_selected, _i18n("All files with status 'added'"), False) |
533.5.1
by Jasper Groenewegen
Remove glade bits of OliveRemove, tweak existing (Olive)RemoveDialog |
53 |
self._button_remove = gtk.Button(stock=gtk.STOCK_REMOVE) |
120
by Szilveszter Farkas (Phanatic)
Use OliveRemoveDialog class instead of OliveRemove. |
54 |
|
55 |
self._button_remove.connect('clicked', self._on_remove_clicked) |
|
56 |
||
533.5.1
by Jasper Groenewegen
Remove glade bits of OliveRemove, tweak existing (Olive)RemoveDialog |
57 |
self.vbox.add(self._label) |
58 |
self.vbox.add(self._radio_selected) |
|
59 |
self.vbox.add(self._radio_added) |
|
60 |
self.vbox.set_spacing(3) |
|
120
by Szilveszter Farkas (Phanatic)
Use OliveRemoveDialog class instead of OliveRemove. |
61 |
self.action_area.pack_end(self._button_remove) |
62 |
||
63 |
self.vbox.show_all() |
|
64 |
||
132
by Jelmer Vernooij
Use decorator for catching and showing bzr-gtk errors graphically. Eventually, this should go away and should be handled by the ui factory. |
65 |
@show_bzr_error
|
120
by Szilveszter Farkas (Phanatic)
Use OliveRemoveDialog class instead of OliveRemove. |
66 |
def _on_remove_clicked(self, button): |
67 |
""" Remove button clicked handler. """ |
|
68 |
if self._radio_selected.get_active(): |
|
69 |
# Remove only the selected file
|
|
70 |
filename = self.selected |
|
71 |
||
72 |
if filename is None: |
|
475.1.2
by Vincent Ladeuil
Fix bug #187283 fix replacing _() by _i18n(). |
73 |
error_dialog(_i18n('No file was selected'), |
74 |
_i18n('Please select a file from the list,\nor choose the other option.')) |
|
120
by Szilveszter Farkas (Phanatic)
Use OliveRemoveDialog class instead of OliveRemove. |
75 |
return
|
76 |
||
132
by Jelmer Vernooij
Use decorator for catching and showing bzr-gtk errors graphically. Eventually, this should go away and should be handled by the ui factory. |
77 |
self.wt.remove(os.path.join(self.wtpath, filename)) |
120
by Szilveszter Farkas (Phanatic)
Use OliveRemoveDialog class instead of OliveRemove. |
78 |
elif self._radio_added.get_active(): |
79 |
# Remove added files recursively
|
|
80 |
added = self.wt.changes_from(self.wt.basis_tree()).added |
|
81 |
file_list = sorted([f[0] for f in added], reverse=True) |
|
82 |
if len(file_list) == 0: |
|
475.1.2
by Vincent Ladeuil
Fix bug #187283 fix replacing _() by _i18n(). |
83 |
warning_dialog(_i18n('No matching files'), |
84 |
_i18n('No added files were found in the working tree.')) |
|
120
by Szilveszter Farkas (Phanatic)
Use OliveRemoveDialog class instead of OliveRemove. |
85 |
return
|
86 |
self.wt.remove(file_list) |
|
87 |
||
88 |
self.response(gtk.RESPONSE_OK) |