/b-gtk/fix-viz

To get this branch, use:
bzr branch http://gegoxaren.bato24.eu/bzr/b-gtk/fix-viz

« back to all changes in this revision

Viewing changes to olive/rename.py

  • Committer: Jasper Groenewegen
  • Date: 2008-07-27 12:01:40 UTC
  • mfrom: (576.3.2 improve-merge)
  • mto: This revision was merged to the branch mainline in revision 579.
  • Revision ID: colbrac@xs4all.nl-20080727120140-1agdlzkc9fumjk5f
Merge merge dialog improvements

Show diffs side-by-side

added added

removed removed

Lines of Context:
23
23
    pass
24
24
 
25
25
import gtk
26
 
import gtk.glade
27
26
 
28
27
import bzrlib.errors as errors
29
28
from bzrlib.workingtree import WorkingTree
30
29
 
31
 
from olive import gladefile
32
 
from dialog import error_dialog
33
 
 
34
 
class OliveRename:
 
30
from bzrlib.plugins.gtk import _i18n
 
31
from bzrlib.plugins.gtk.dialog import error_dialog
 
32
from bzrlib.plugins.gtk.errors import show_bzr_error
 
33
 
 
34
 
 
35
class RenameDialog(gtk.Dialog):
35
36
    """ Display the Rename dialog and perform the needed actions. """
36
 
    def __init__(self, wt, wtpath, selected=[]):
37
 
        """ Initialize the Rename dialog. """
38
 
        self.glade = gtk.glade.XML(gladefile, 'window_rename')
39
 
        
40
 
        self.window = self.glade.get_widget('window_rename')
41
 
        
42
 
        # Dictionary for signal_autoconnect
43
 
        dic = { "on_button_rename_rename_clicked": self.rename,
44
 
                "on_button_rename_cancel_clicked": self.close }
45
 
        
46
 
        # Connect the signals to the handlers
47
 
        self.glade.signal_autoconnect(dic)
48
 
        
 
37
    
 
38
    def __init__(self, wt, wtpath, selected=None, parent=None):
 
39
        """ Initialize the Rename file dialog. """
 
40
        gtk.Dialog.__init__(self, title="Olive - Rename files",
 
41
                                  parent=parent,
 
42
                                  flags=0,
 
43
                                  buttons=(gtk.STOCK_CANCEL, gtk.RESPONSE_CANCEL))
 
44
        
 
45
        # Get arguments
49
46
        self.wt = wt
50
47
        self.wtpath = wtpath
51
48
        self.selected = selected
52
49
        
53
 
    def display(self):
54
 
        """ Display the Rename dialog. """
55
 
        self.window.show_all()
56
 
 
57
 
    def rename(self, widget):
 
50
        # Create widgets
 
51
        self._hbox = gtk.HBox()
 
52
        self._label_rename_to = gtk.Label(_i18n("Rename to"))
 
53
        self._entry = gtk.Entry()
 
54
        self._button_rename = gtk.Button(_i18n("_Rename"))
 
55
        self._button_rename_icon = gtk.Image()
 
56
        self._button_rename_icon.set_from_stock(gtk.STOCK_APPLY, gtk.ICON_SIZE_BUTTON)
 
57
        self._button_rename.set_image(self._button_rename_icon)
 
58
        
 
59
        self._entry.connect('activate', self._on_rename_clicked)
 
60
        self._button_rename.connect('clicked', self._on_rename_clicked)
 
61
        
 
62
        # Set text
 
63
        if self.selected is not None:
 
64
            self._entry.set_text(self.selected)
 
65
        
 
66
        # Add widgets to dialog
 
67
        self.vbox.add(self._hbox)
 
68
        self._hbox.add(self._label_rename_to)
 
69
        self._hbox.add(self._entry)
 
70
        self._hbox.set_spacing(5)
 
71
        self.action_area.pack_end(self._button_rename)
 
72
        
 
73
        self.vbox.show_all()
 
74
        
 
75
    @show_bzr_error
 
76
    def _on_rename_clicked(self, widget):
58
77
        # Get entry
59
 
        entry = self.glade.get_widget('entry_rename')
60
 
        
61
78
        old_filename = self.selected
62
 
        new_filename = entry.get_text()
 
79
        new_filename = self._entry.get_text()
63
80
            
64
81
        if old_filename is None:
65
 
            error_dialog(_('No file was selected'),
66
 
                         _('Please select a file from the list to proceed.'))
 
82
            error_dialog(_i18n('No file was selected'),
 
83
                         _i18n('Please select a file from the list to proceed.'))
67
84
            return
68
85
        
69
86
        if new_filename == "":
70
 
            error_dialog(_('Filename not given'),
71
 
                         _('Please specify a new name for the file.'))
 
87
            error_dialog(_i18n('Filename not given'),
 
88
                         _i18n('Please specify a new name for the file.'))
72
89
            return
73
90
        
74
91
        source = os.path.join(self.wtpath, old_filename)
75
92
        destination = os.path.join(self.wtpath, new_filename)
76
93
        
77
94
        # Rename the file
78
 
        try:
79
 
            wt1, path1 = WorkingTree.open_containing(self.wt.abspath(source))
80
 
            wt2, path2 = WorkingTree.open_containing(self.wt.abspath(source))
 
95
        wt1, path1 = WorkingTree.open_containing(self.wt.abspath(source))
 
96
        wt2, path2 = WorkingTree.open_containing(self.wt.abspath(source))
81
97
 
82
 
            if wt1.basedir != wt2.basedir:
83
 
                error_dialog(_('Not the same branch'),
84
 
                             _('The destination is not in the same branch.'))
85
 
                return
86
 
            wt1.rename_one(source, destination)
87
 
        except errors.NotBranchError:
88
 
            error_dialog(_('File is not in a branch'),
89
 
                         _('The selected file is not in a branch.'))
 
98
        if wt1.basedir != wt2.basedir:
 
99
            error_dialog(_i18n('Not the same branch'),
 
100
                         _i18n('The destination is not in the same branch.'))
90
101
            return
91
 
        except errors.BzrError, msg:
92
 
            error_dialog(_('Unknown bzr error'), str(msg))
93
 
 
94
 
        self.close()
95
 
    
96
 
    def close(self, widget=None):
97
 
        self.window.destroy()
 
102
        wt1.rename_one(source, destination)
 
103
        
 
104
        self.response(gtk.RESPONSE_OK)