/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/checkout.py

  • Committer: Jelmer Vernooij
  • Date: 2006-05-19 16:56:46 UTC
  • mfrom: (0.1.25 gannotate)
  • Revision ID: jelmer@samba.org-20060519165646-0d867938fdbc9097
Merge in Dan Loda's gannotate plugin and put it in annotate/

Show diffs side-by-side

added added

removed removed

Lines of Context:
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 sys
18
 
 
19
 
try:
20
 
    import pygtk
21
 
    pygtk.require("2.0")
22
 
except:
23
 
    pass
24
 
try:
25
 
    import gtk
26
 
    import gtk.glade
27
 
except:
28
 
    sys.exit(1)
29
 
 
30
 
import bzrlib.errors as errors
31
 
 
32
 
class OliveCheckout:
33
 
    """ Display checkout dialog and perform the needed operations. """
34
 
    def __init__(self, gladefile, comm, dialog):
35
 
        """ Initialize the Checkout dialog. """
36
 
        self.gladefile = gladefile
37
 
        self.glade = gtk.glade.XML(self.gladefile, 'window_checkout', 'olive-gtk')
38
 
        
39
 
        # Communication object
40
 
        self.comm = comm
41
 
        # Dialog object
42
 
        self.dialog = dialog
43
 
        
44
 
        self.window = self.glade.get_widget('window_checkout')
45
 
        
46
 
        # Dictionary for signal_autoconnect
47
 
        dic = { "on_button_checkout_checkout_clicked": self.checkout,
48
 
                "on_button_checkout_cancel_clicked": self.close }
49
 
        
50
 
        # Connect the signals to the handlers
51
 
        self.glade.signal_autoconnect(dic)
52
 
        
53
 
        # Save FileChooser state
54
 
        self.filechooser = self.glade.get_widget('filechooserbutton_checkout')
55
 
        self.filechooser.set_filename(self.comm.get_path())
56
 
 
57
 
    def display(self):
58
 
        """ Display the Checkout dialog. """
59
 
        self.window.show_all()
60
 
    
61
 
    def checkout(self, widget):
62
 
        entry_location = self.glade.get_widget('entry_checkout_location')
63
 
        location = entry_location.get_text()
64
 
        if location is '':
65
 
            self.dialog.error_dialog(_('Missing branch location'),
66
 
                                     _('You must specify a branch location.'))
67
 
            return
68
 
        
69
 
        destination = self.filechooser.get_filename()
70
 
        
71
 
        spinbutton_revno = self.glade.get_widget('spinbutton_checkout_revno')
72
 
        revno = spinbutton_revno.get_value_as_int()
73
 
        rev_id = source.get_rev_id(revno)
74
 
        
75
 
        checkbutton_lightweight = self.glade.get_widget('checkbutton_checkout_lightweight')
76
 
        lightweight = checkbutton_lightweight.get_active()
77
 
        
78
 
        self.comm.set_busy(self.window)
79
 
        try:
80
 
            source = Branch.open(location)
81
 
            
82
 
            # if the source and destination are the same, 
83
 
            # and there is no working tree,
84
 
            # then reconstitute a branch
85
 
            if (bzrlib.osutils.abspath(destination) ==
86
 
                bzrlib.osutils.abspath(location)):
87
 
                try:
88
 
                    source.bzrdir.open_workingtree()
89
 
                except NoWorkingTree:
90
 
                    source.bzrdir.create_workingtree()
91
 
                    return
92
 
 
93
 
            destination = destination + '/' + os.path.basename(location.rstrip("/\\"))
94
 
            
95
 
            os.mkdir(destination)
96
 
 
97
 
            old_format = bzrlib.bzrdir.BzrDirFormat.get_default_format()
98
 
            bzrlib.bzrdir.BzrDirFormat.set_default_format(bzrdir.BzrDirMetaFormat1())
99
 
 
100
 
            try:
101
 
                if lightweight:
102
 
                    checkout = bzrdir.BzrDirMetaFormat1().initialize(destination)
103
 
                    bzrlib.branch.BranchReferenceFormat().initialize(checkout, source)
104
 
                else:
105
 
                    checkout_branch = bzrlib.bzrdir.BzrDir.create_branch_convenience(
106
 
                        destination, force_new_tree=False)
107
 
                    checkout = checkout_branch.bzrdir
108
 
                    checkout_branch.bind(source)
109
 
                    if rev_id is not None:
110
 
                        rh = checkout_branch.revno_history()
111
 
                        checkout_branch.set_revno_history(rh[:rh.index(rev_id) + 1])
112
 
 
113
 
                checkout.create_workingtree(rev_id)
114
 
            finally:
115
 
                bzrlib.bzrdir.BzrDirFormat.set_default_format(old_format)
116
 
        except errors.NotBranchError, errmsg:
117
 
            self.dialog.error_dialog(_('Location is not a branch'),
118
 
                                     _('The specified location has to be a branch.'))
119
 
            self.comm.set_busy(self.window, False)
120
 
            return
121
 
        except errors.TargetAlreadyExists, errmsg:
122
 
            self.dialog.error_dialog(_('Target already exists'),
123
 
                                     _('Target directory (%s)\nalready exists. Please select another target.') % errmsg)
124
 
            self.comm.set_busy(self.window, False)
125
 
            return
126
 
        except errors.NonExistingParent, errmsg:
127
 
            self.dialog.error_dialog(_('Non existing parent directory'),
128
 
                                     _("The parent directory (%s)\ndoesn't exist.") % errmsg)
129
 
            self.comm.set_busy(self.window, False)
130
 
            return
131
 
        except:
132
 
            raise
133
 
        
134
 
        self.close()
135
 
        self.comm.refresh_right()
136
 
 
137
 
    def close(self, widget=None):
138
 
        self.window.destroy()