/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: Scott James Remnant
  • Date: 2005-10-17 01:07:49 UTC
  • Revision ID: scott@netsplit.com-20051017010749-15fa95fc2cf09289
Commit the first version of bzrk.

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()