/b-gtk/fix-viz

To get this branch, use:
bzr branch http://gegoxaren.bato24.eu/bzr/b-gtk/fix-viz
0.8.40 by Szilveszter Farkas (Phanatic)
Implemented Rename functionality.
1
# Copyright (C) 2006 by Szilveszter Farkas (Phanatic) <szilveszter.farkas@gmail.com>
2
#
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.
7
#
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.
12
#
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
17
import os
18
import sys
19
20
try:
21
    import pygtk
22
    pygtk.require("2.0")
23
except:
24
    pass
25
try:
26
    import gtk
27
    import gtk.glade
28
except:
29
    sys.exit(1)
30
0.11.1 by Jelmer Vernooij
Eliminate olive.backend.errors.
31
import bzrlib.errors as errors
0.8.40 by Szilveszter Farkas (Phanatic)
Implemented Rename functionality.
32
33
class OliveRename:
34
    """ Display the Rename dialog and perform the needed actions. """
0.8.46 by Szilveszter Farkas (Phanatic)
Modified OliveDialog class interface; huge cleanups.
35
    def __init__(self, gladefile, comm, dialog):
0.8.40 by Szilveszter Farkas (Phanatic)
Implemented Rename functionality.
36
        """ Initialize the Rename dialog. """
37
        self.gladefile = gladefile
38
        self.glade = gtk.glade.XML(self.gladefile, 'window_rename')
39
        
0.8.46 by Szilveszter Farkas (Phanatic)
Modified OliveDialog class interface; huge cleanups.
40
        # Communication object
0.8.40 by Szilveszter Farkas (Phanatic)
Implemented Rename functionality.
41
        self.comm = comm
0.8.46 by Szilveszter Farkas (Phanatic)
Modified OliveDialog class interface; huge cleanups.
42
        # Dialog object
43
        self.dialog = dialog
0.8.40 by Szilveszter Farkas (Phanatic)
Implemented Rename functionality.
44
        
45
        self.window = self.glade.get_widget('window_rename')
46
        
47
        # Dictionary for signal_autoconnect
48
        dic = { "on_button_rename_rename_clicked": self.rename,
49
                "on_button_rename_cancel_clicked": self.close }
50
        
51
        # Connect the signals to the handlers
52
        self.glade.signal_autoconnect(dic)
53
        
54
    def display(self):
55
        """ Display the Rename dialog. """
56
        self.window.show_all()
57
58
    def rename(self, widget):
59
        # Get entry
60
        entry = self.glade.get_widget('entry_rename')
61
        
62
        old_filename = self.comm.get_selected_right()
63
        new_filename = entry.get_text()
64
            
65
        if old_filename is None:
0.8.55 by Szilveszter Farkas (Phanatic)
Gettext support added.
66
            self.dialog.error_dialog(_('No file was selected'),
67
                                     _('Please select a file from the list to proceed.'))
0.8.40 by Szilveszter Farkas (Phanatic)
Implemented Rename functionality.
68
            return
69
        
70
        if new_filename == "":
0.8.55 by Szilveszter Farkas (Phanatic)
Gettext support added.
71
            self.dialog.error_dialog(_('Filename not given'),
72
                                     _('Please specify a new name for the file.'))
0.8.40 by Szilveszter Farkas (Phanatic)
Implemented Rename functionality.
73
            return
74
        
75
        source = self.comm.get_path() + '/' + old_filename
76
        destination = self.comm.get_path() + '/' + new_filename
77
        
78
        # Rename the file
79
        try:
0.11.8 by Jelmer Vernooij
Integrate olive.backend.fileops
80
            wt1, path1 = WorkingTree.open_containing(source)
81
            wt2, path2 = WorkingTree.open_containing(source)
82
83
            if wt1.base != wt2.base:
84
                self.dialog.error_dialog(_('Not the same branch'),
85
                                         _('The destination is not in the same branch.'))
86
                return
87
            wt1.rename_one(source, destination)
0.8.40 by Szilveszter Farkas (Phanatic)
Implemented Rename functionality.
88
        except errors.NotBranchError:
0.8.55 by Szilveszter Farkas (Phanatic)
Gettext support added.
89
            self.dialog.error_dialog(_('File is not in a branch'),
90
                                     _('The selected file is not in a branch.'))
0.8.40 by Szilveszter Farkas (Phanatic)
Implemented Rename functionality.
91
            return
92
93
        self.close()
94
        self.comm.refresh_right()
95
    
96
    def close(self, widget=None):
97
        self.window.destroy()