~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: 2009-10-06 20:45:48 UTC
  • mfrom: (4728.1.2 integration)
  • Revision ID: pqm@pqm.ubuntu.com-20091006204548-bjnc3z4k256ppimz
MutableTree.has_changes() does not require a tree parameter anymore

Show diffs side-by-side

added added

removed removed

Lines of Context:
17
17
"""bzr upgrade logic."""
18
18
 
19
19
 
20
 
from bzrlib.bzrdir import BzrDir, BzrDirFormat
 
20
from bzrlib.bzrdir import BzrDir, BzrDirFormat, format_registry
21
21
import bzrlib.errors as errors
22
22
from bzrlib.remote import RemoteBzrDir
23
23
from bzrlib.transport import get_transport
26
26
 
27
27
class Convert(object):
28
28
 
29
 
    def __init__(self, url, format):
30
 
        if format is None:
31
 
            format = BzrDirFormat.get_default_format()
 
29
    def __init__(self, url, format=None):
32
30
        self.format = format
33
31
        self.bzrdir = BzrDir.open_unsupported(url)
34
32
        if isinstance(self.bzrdir, RemoteBzrDir):
48
46
            branch = self.bzrdir.open_branch()
49
47
            if branch.bzrdir.root_transport.base != \
50
48
                self.bzrdir.root_transport.base:
51
 
                self.pb.note("This is a checkout. The branch (%s) needs to be "
52
 
                             "upgraded separately.",
 
49
                ui.ui_factory.note("This is a checkout. The branch (%s) needs to be "
 
50
                             "upgraded separately." %
53
51
                             branch.bzrdir.root_transport.base)
54
52
            del branch
55
53
        except (errors.NotBranchError, errors.IncompatibleRepositories):
56
54
            # might not be a format we can open without upgrading; see e.g.
57
55
            # https://bugs.launchpad.net/bzr/+bug/253891
58
56
            pass
59
 
        if not self.bzrdir.needs_format_conversion(self.format):
 
57
        if self.format is None:
 
58
            try:
 
59
                rich_root = self.bzrdir.find_repository()._format.rich_root_data
 
60
            except errors.NoRepositoryPresent:
 
61
                rich_root = False # assume no rich roots
 
62
            if rich_root:
 
63
                format_name = "default-rich-root"
 
64
            else:
 
65
                format_name = "default"
 
66
            format = format_registry.make_bzrdir(format_name)
 
67
        else:
 
68
            format = self.format
 
69
        if not self.bzrdir.needs_format_conversion(format):
60
70
            raise errors.UpToDateFormat(self.bzrdir._format)
61
71
        if not self.bzrdir.can_convert_format():
62
72
            raise errors.BzrError("cannot upgrade from bzrdir format %s" %
63
73
                           self.bzrdir._format)
64
 
        self.bzrdir.check_conversion_target(self.format)
65
 
        self.pb.note('starting upgrade of %s', self.transport.base)
 
74
        self.bzrdir.check_conversion_target(format)
 
75
        ui.ui_factory.note('starting upgrade of %s' % self.transport.base)
 
76
 
66
77
        self.bzrdir.backup_bzrdir()
67
 
        while self.bzrdir.needs_format_conversion(self.format):
68
 
            converter = self.bzrdir._format.get_converter(self.format)
 
78
        while self.bzrdir.needs_format_conversion(format):
 
79
            converter = self.bzrdir._format.get_converter(format)
69
80
            self.bzrdir = converter.convert(self.bzrdir, self.pb)
70
 
        self.pb.note("finished")
 
81
        ui.ui_factory.note("finished")
71
82
 
72
83
 
73
84
def upgrade(url, format=None):