~bzr-pqm/bzr/bzr.dev

« back to all changes in this revision

Viewing changes to bzrlib/upgrade.py

  • Committer: John Arbash Meinel
  • Date: 2009-03-27 22:29:55 UTC
  • mto: (3735.39.2 clean)
  • mto: This revision was merged to the branch mainline in revision 4280.
  • Revision ID: john@arbash-meinel.com-20090327222955-utifmfm888zerixt
Implement apply_delta_to_source which doesn't have to malloc another string.

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, 2008, 2009 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
17
17
"""bzr upgrade logic."""
18
18
 
19
19
 
20
 
from bzrlib.bzrdir import BzrDir, format_registry
 
20
from bzrlib.bzrdir import BzrDir, BzrDirFormat
21
21
import bzrlib.errors as errors
22
22
from bzrlib.remote import RemoteBzrDir
 
23
from bzrlib.transport import get_transport
23
24
import bzrlib.ui as ui
24
25
 
25
26
 
26
27
class Convert(object):
27
28
 
28
 
    def __init__(self, url, format=None):
 
29
    def __init__(self, url, format):
 
30
        if format is None:
 
31
            format = BzrDirFormat.get_default_format()
29
32
        self.format = format
30
33
        self.bzrdir = BzrDir.open_unsupported(url)
31
 
        # XXX: Change to cleanup
32
 
        warning_id = 'cross_format_fetch'
33
 
        saved_warning = warning_id in ui.ui_factory.suppressed_warnings
34
34
        if isinstance(self.bzrdir, RemoteBzrDir):
35
35
            self.bzrdir._ensure_real()
36
36
            self.bzrdir = self.bzrdir._real_bzrdir
37
37
        if self.bzrdir.root_transport.is_readonly():
38
38
            raise errors.UpgradeReadonly
39
39
        self.transport = self.bzrdir.root_transport
40
 
        ui.ui_factory.suppressed_warnings.add(warning_id)
 
40
        self.pb = ui.ui_factory.nested_progress_bar()
41
41
        try:
42
42
            self.convert()
43
43
        finally:
44
 
            if not saved_warning:
45
 
                ui.ui_factory.suppressed_warnings.remove(warning_id)
 
44
            self.pb.finished()
46
45
 
47
46
    def convert(self):
48
47
        try:
49
48
            branch = self.bzrdir.open_branch()
50
 
            if branch.user_url != self.bzrdir.user_url:
51
 
                ui.ui_factory.note("This is a checkout. The branch (%s) needs to be "
52
 
                             "upgraded separately." %
53
 
                             branch.user_url)
 
49
            if branch.bzrdir.root_transport.base != \
 
50
                self.bzrdir.root_transport.base:
 
51
                self.pb.note("This is a checkout. The branch (%s) needs to be "
 
52
                             "upgraded separately.",
 
53
                             branch.bzrdir.root_transport.base)
54
54
            del branch
55
55
        except (errors.NotBranchError, errors.IncompatibleRepositories):
56
56
            # might not be a format we can open without upgrading; see e.g.
57
57
            # https://bugs.launchpad.net/bzr/+bug/253891
58
58
            pass
59
 
        if self.format is None:
60
 
            try:
61
 
                rich_root = self.bzrdir.find_repository()._format.rich_root_data
62
 
            except errors.NoRepositoryPresent:
63
 
                rich_root = False # assume no rich roots
64
 
            if rich_root:
65
 
                format_name = "default-rich-root"
66
 
            else:
67
 
                format_name = "default"
68
 
            format = format_registry.make_bzrdir(format_name)
69
 
        else:
70
 
            format = self.format
71
 
        if not self.bzrdir.needs_format_conversion(format):
 
59
        if not self.bzrdir.needs_format_conversion(self.format):
72
60
            raise errors.UpToDateFormat(self.bzrdir._format)
73
61
        if not self.bzrdir.can_convert_format():
74
62
            raise errors.BzrError("cannot upgrade from bzrdir format %s" %
75
63
                           self.bzrdir._format)
76
 
        self.bzrdir.check_conversion_target(format)
77
 
        ui.ui_factory.note('starting upgrade of %s' % self.transport.base)
78
 
 
 
64
        self.bzrdir.check_conversion_target(self.format)
 
65
        self.pb.note('starting upgrade of %s', self.transport.base)
79
66
        self.bzrdir.backup_bzrdir()
80
 
        while self.bzrdir.needs_format_conversion(format):
81
 
            converter = self.bzrdir._format.get_converter(format)
82
 
            self.bzrdir = converter.convert(self.bzrdir, None)
83
 
        ui.ui_factory.note("finished")
 
67
        while self.bzrdir.needs_format_conversion(self.format):
 
68
            converter = self.bzrdir._format.get_converter(self.format)
 
69
            self.bzrdir = converter.convert(self.bzrdir, self.pb)
 
70
        self.pb.note("finished")
84
71
 
85
72
 
86
73
def upgrade(url, format=None):