~bzr-pqm/bzr/bzr.dev

« back to all changes in this revision

Viewing changes to bzrlib/upgrade.py

  • Committer: Canonical.com Patch Queue Manager
  • Date: 2006-05-21 23:35:20 UTC
  • mfrom: (1721.1.1 integration)
  • Revision ID: pqm@pqm.ubuntu.com-20060521233520-7f8a0248d93bde80
Some tests for bzr ignored. (Robert Collins).

Show diffs side-by-side

added added

removed removed

Lines of Context:
1
 
# Copyright (C) 2005, 2006, 2008, 2009, 2010 Canonical Ltd
 
1
# Copyright (C) 2005 Canonical Ltd
2
2
#
3
3
# This program is free software; you can redistribute it and/or modify
4
4
# it under the terms of the GNU General Public License as published by
12
12
#
13
13
# You should have received a copy of the GNU General Public License
14
14
# along with this program; if not, write to the Free Software
15
 
# Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
 
15
# Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA
16
16
 
17
17
"""bzr upgrade logic."""
18
18
 
19
 
 
20
 
from bzrlib.bzrdir import BzrDir, format_registry
 
19
# change upgrade from .bzr to create a '.bzr-new', then do a bait and switch.
 
20
 
 
21
 
 
22
from bzrlib.bzrdir import ConvertBzrDir4To5, ConvertBzrDir5To6, BzrDir, BzrDirFormat4, BzrDirFormat5
21
23
import bzrlib.errors as errors
22
 
from bzrlib.remote import RemoteBzrDir
 
24
from bzrlib.transport import get_transport
23
25
import bzrlib.ui as ui
24
26
 
25
27
 
26
28
class Convert(object):
27
29
 
28
 
    def __init__(self, url, format=None):
 
30
    def __init__(self, url, format):
29
31
        self.format = format
30
32
        self.bzrdir = BzrDir.open_unsupported(url)
31
 
        if isinstance(self.bzrdir, RemoteBzrDir):
32
 
            self.bzrdir._ensure_real()
33
 
            self.bzrdir = self.bzrdir._real_bzrdir
34
33
        if self.bzrdir.root_transport.is_readonly():
35
34
            raise errors.UpgradeReadonly
36
35
        self.transport = self.bzrdir.root_transport
37
 
        self.convert()
 
36
        self.pb = ui.ui_factory.nested_progress_bar()
 
37
        try:
 
38
            self.convert()
 
39
        finally:
 
40
            self.pb.finished()
38
41
 
39
42
    def convert(self):
40
43
        try:
41
44
            branch = self.bzrdir.open_branch()
42
45
            if branch.bzrdir.root_transport.base != \
43
46
                self.bzrdir.root_transport.base:
44
 
                ui.ui_factory.note("This is a checkout. The branch (%s) needs to be "
45
 
                             "upgraded separately." %
 
47
                self.pb.note("This is a checkout. The branch (%s) needs to be "
 
48
                             "upgraded separately.",
46
49
                             branch.bzrdir.root_transport.base)
47
 
            del branch
48
 
        except (errors.NotBranchError, errors.IncompatibleRepositories):
49
 
            # might not be a format we can open without upgrading; see e.g.
50
 
            # https://bugs.launchpad.net/bzr/+bug/253891
 
50
        except errors.NotBranchError:
51
51
            pass
52
 
        if self.format is None:
53
 
            try:
54
 
                rich_root = self.bzrdir.find_repository()._format.rich_root_data
55
 
            except errors.NoRepositoryPresent:
56
 
                rich_root = False # assume no rich roots
57
 
            if rich_root:
58
 
                format_name = "default-rich-root"
59
 
            else:
60
 
                format_name = "default"
61
 
            format = format_registry.make_bzrdir(format_name)
62
 
        else:
63
 
            format = self.format
64
 
        if not self.bzrdir.needs_format_conversion(format):
 
52
        if not self.bzrdir.needs_format_conversion(self.format):
65
53
            raise errors.UpToDateFormat(self.bzrdir._format)
66
54
        if not self.bzrdir.can_convert_format():
67
 
            raise errors.BzrError("cannot upgrade from bzrdir format %s" %
 
55
            raise errors.BzrError("cannot upgrade from branch format %s" %
68
56
                           self.bzrdir._format)
69
 
        self.bzrdir.check_conversion_target(format)
70
 
        ui.ui_factory.note('starting upgrade of %s' % self.transport.base)
71
 
 
72
 
        self.bzrdir.backup_bzrdir()
73
 
        while self.bzrdir.needs_format_conversion(format):
74
 
            converter = self.bzrdir._format.get_converter(format)
75
 
            self.bzrdir = converter.convert(self.bzrdir, None)
76
 
        ui.ui_factory.note("finished")
77
 
 
 
57
        self.pb.note('starting upgrade of %s', self.transport.base)
 
58
        self._backup_control_dir()
 
59
        while self.bzrdir.needs_format_conversion(self.format):
 
60
            converter = self.bzrdir._format.get_converter(self.format)
 
61
            self.bzrdir = converter.convert(self.bzrdir, self.pb)
 
62
        self.pb.note("finished")
 
63
 
 
64
    def _backup_control_dir(self):
 
65
        self.pb.note('making backup of tree history')
 
66
        self.transport.copy_tree('.bzr', '.bzr.backup')
 
67
        self.pb.note('%s.bzr has been backed up to %s.bzr.backup',
 
68
             self.transport.base,
 
69
             self.transport.base)
 
70
        self.pb.note('if conversion fails, you can move this directory back to .bzr')
 
71
        self.pb.note('if it succeeds, you can remove this directory if you wish')
78
72
 
79
73
def upgrade(url, format=None):
80
74
    """Upgrade to format, or the default bzrdir format if not supplied."""