/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-09-29 20:59:52 UTC
  • mfrom: (0.8.92 merge)
  • Revision ID: jelmer@samba.org-20060929205952-32ce1f02b7cf334b
MergeĀ OliveĀ code.

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