~jelmer/ubuntu/maverick/bzr/2.2.5

« back to all changes in this revision

Viewing changes to bzrlib/upgrade.py

  • Committer: Bazaar Package Importer
  • Author(s): Jelmer Vernooij
  • Date: 2009-03-10 14:11:59 UTC
  • mfrom: (1.2.1 upstream) (3.1.68 jaunty)
  • Revision ID: james.westby@ubuntu.com-20090310141159-lwzzo5c1fwrtzgj4
New upstream release.

Show diffs side-by-side

added added

removed removed

Lines of Context:
1
 
# Copyright (C) 2005 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
16
16
 
17
17
"""bzr upgrade logic."""
18
18
 
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, BzrDirFormat
 
19
 
 
20
from bzrlib.bzrdir import BzrDir, BzrDirFormat
23
21
import bzrlib.errors as errors
 
22
from bzrlib.remote import RemoteBzrDir
24
23
from bzrlib.transport import get_transport
25
24
import bzrlib.ui as ui
26
25
 
28
27
class Convert(object):
29
28
 
30
29
    def __init__(self, url, format):
 
30
        if format is None:
 
31
            format = BzrDirFormat.get_default_format()
31
32
        self.format = format
32
33
        self.bzrdir = BzrDir.open_unsupported(url)
 
34
        if isinstance(self.bzrdir, RemoteBzrDir):
 
35
            self.bzrdir._ensure_real()
 
36
            self.bzrdir = self.bzrdir._real_bzrdir
33
37
        if self.bzrdir.root_transport.is_readonly():
34
38
            raise errors.UpgradeReadonly
35
39
        self.transport = self.bzrdir.root_transport
47
51
                self.pb.note("This is a checkout. The branch (%s) needs to be "
48
52
                             "upgraded separately.",
49
53
                             branch.bzrdir.root_transport.base)
50
 
        except errors.NotBranchError:
 
54
            del branch
 
55
        except (errors.NotBranchError, errors.IncompatibleRepositories):
 
56
            # might not be a format we can open without upgrading; see e.g.
 
57
            # https://bugs.launchpad.net/bzr/+bug/253891
51
58
            pass
52
59
        if not self.bzrdir.needs_format_conversion(self.format):
53
60
            raise errors.UpToDateFormat(self.bzrdir._format)
54
61
        if not self.bzrdir.can_convert_format():
55
 
            raise errors.BzrError("cannot upgrade from branch format %s" %
 
62
            raise errors.BzrError("cannot upgrade from bzrdir format %s" %
56
63
                           self.bzrdir._format)
57
 
        if self.format is None:
58
 
            target_format = BzrDirFormat.get_default_format()
59
 
        else:
60
 
            target_format = self.format
61
 
        self.bzrdir.check_conversion_target(target_format)
 
64
        self.bzrdir.check_conversion_target(self.format)
62
65
        self.pb.note('starting upgrade of %s', self.transport.base)
63
 
        self._backup_control_dir()
 
66
        self.bzrdir.backup_bzrdir()
64
67
        while self.bzrdir.needs_format_conversion(self.format):
65
68
            converter = self.bzrdir._format.get_converter(self.format)
66
69
            self.bzrdir = converter.convert(self.bzrdir, self.pb)
67
70
        self.pb.note("finished")
68
71
 
69
 
    def _backup_control_dir(self):
70
 
        self.pb.note('making backup of tree history')
71
 
        self.transport.copy_tree('.bzr', 'backup.bzr')
72
 
        self.pb.note('%s.bzr has been backed up to %sbackup.bzr',
73
 
             self.transport.base,
74
 
             self.transport.base)
75
 
        self.pb.note('if conversion fails, you can move this directory back to .bzr')
76
 
        self.pb.note('if it succeeds, you can remove this directory if you wish')
77
72
 
78
73
def upgrade(url, format=None):
79
74
    """Upgrade to format, or the default bzrdir format if not supplied."""