/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: Szilveszter Farkas (Phanatic)
  • Date: 2006-09-30 11:01:59 UTC
  • mto: (0.14.3 main)
  • mto: This revision was merged to the branch mainline in revision 86.
  • Revision ID: Szilveszter.Farkas@gmail.com-20060930110159-d1d716766985f3dd
Fix Move, Rename and glade file.

Show diffs side-by-side

added added

removed removed

Lines of Context:
15
15
# Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA
16
16
 
17
17
import os
18
 
import sys
19
18
 
20
19
try:
21
20
    import pygtk
27
26
import gtk.glade
28
27
 
29
28
import bzrlib.errors as errors
 
29
from bzrlib.workingtree import WorkingTree
 
30
 
 
31
from olive import gladefile
 
32
from dialog import error_dialog
30
33
 
31
34
class OliveRename:
32
35
    """ Display the Rename dialog and perform the needed actions. """
33
 
    def __init__(self, comm):
 
36
    def __init__(self, wt, wtpath, selected=[]):
34
37
        """ Initialize the Rename dialog. """
35
38
        self.glade = gtk.glade.XML(gladefile, 'window_rename')
36
39
        
37
 
        # Communication object
38
 
        self.comm = comm
39
 
        
40
40
        self.window = self.glade.get_widget('window_rename')
41
41
        
42
42
        # Dictionary for signal_autoconnect
46
46
        # Connect the signals to the handlers
47
47
        self.glade.signal_autoconnect(dic)
48
48
        
 
49
        self.wt = wt
 
50
        self.wtpath = wtpath
 
51
        self.selected = selected
 
52
        
49
53
    def display(self):
50
54
        """ Display the Rename dialog. """
51
55
        self.window.show_all()
54
58
        # Get entry
55
59
        entry = self.glade.get_widget('entry_rename')
56
60
        
57
 
        old_filename = self.comm.get_selected_right()
 
61
        old_filename = self.selected
58
62
        new_filename = entry.get_text()
59
63
            
60
64
        if old_filename is None:
61
65
            error_dialog(_('No file was selected'),
62
 
                                     _('Please select a file from the list to proceed.'))
 
66
                         _('Please select a file from the list to proceed.'))
63
67
            return
64
68
        
65
69
        if new_filename == "":
66
70
            error_dialog(_('Filename not given'),
67
 
                                     _('Please specify a new name for the file.'))
 
71
                         _('Please specify a new name for the file.'))
68
72
            return
69
73
        
70
 
        source = self.comm.get_path() + '/' + old_filename
71
 
        destination = self.comm.get_path() + '/' + new_filename
 
74
        if self.wtpath == "":
 
75
            source = self.wt.abspath(old_filename)
 
76
            destination = self.wt.abspath(new_filename)
 
77
        else:
 
78
            source = self.wt.abspath(self.wtpath + os.sep + old_filename)
 
79
            destination = self.wt.abspath(self.wtpath + os.sep + new_filename)
72
80
        
73
81
        # Rename the file
74
82
        try:
77
85
 
78
86
            if wt1.base != wt2.base:
79
87
                error_dialog(_('Not the same branch'),
80
 
                                         _('The destination is not in the same branch.'))
 
88
                             _('The destination is not in the same branch.'))
81
89
                return
82
90
            wt1.rename_one(source, destination)
83
91
        except errors.NotBranchError:
84
92
            error_dialog(_('File is not in a branch'),
85
 
                                     _('The selected file is not in a branch.'))
 
93
                         _('The selected file is not in a branch.'))
86
94
            return
87
95
 
88
96
        self.close()
89
 
        self.comm.refresh_right()
90
97
    
91
98
    def close(self, widget=None):
92
99
        self.window.destroy()