/brz/remove-bazaar

To get this branch, use:
bzr branch http://gegoxaren.bato24.eu/bzr/brz/remove-bazaar

« back to all changes in this revision

Viewing changes to bzrlib/upgrade.py

  • Committer: Vincent Ladeuil
  • Date: 2007-12-08 23:15:18 UTC
  • mto: (2929.3.16 https) (3097.2.1 trunk)
  • mto: This revision was merged to the branch mainline in revision 3099.
  • Revision ID: v.ladeuil+lp@free.fr-20071208231518-sj2ui57xyd4mkjra
Limit GET requests by body size instead of number of ranges.

* bzrlib/transport/http/response.py:
Fix some error messages.
(RangeFile.read_range_definition): Keep the range headers in the
_headers attribute for easier debugging (especially for remote
debugging).

* bzrlib/transport/http/_pycurl.py:
(PyCurlTransport): Replace _max_readv_combine by _get_max_size
which is more approriate to the problem.

* bzrlib/transport/http/__init__.py:
(HttpTransportBase): Add a _get_max_size class attribute
corresponding to the max_size _coalesced_offets max_size
parameter.
(HttpTransportBase._coalesce_readv): Limit the size of the get
requests if _get_max_size is greater than 0 while still respecting
the maximum number of ranges in a request.

* bzrlib/tests/test_http.py:
(TestRangeRequestServer.test_readv_get_max_size): Test the
_get_max_size parameter.

* bzrlib/transport/__init__.py:
(Transport._coalesce_offsets): Add a max_size parameter limiting
the size of the coalesced offsets.

* bzrlib/tests/test_transport.py:
(TestCoalesceOffsets.check): Add the max_size parameter.
(TestCoalesceOffsets.test_coalesce_max_size,
TestCoalesceOffsets.test_coalesce_no_max_size): Test the max_size
parameter.

Show diffs side-by-side

added added

removed removed

Lines of Context:
 
1
# Copyright (C) 2005 Canonical Ltd
 
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
"""bzr upgrade logic."""
 
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
 
23
import bzrlib.errors as errors
 
24
from bzrlib.transport import get_transport
 
25
import bzrlib.ui as ui
 
26
 
 
27
 
 
28
class Convert(object):
 
29
 
 
30
    def __init__(self, url, format):
 
31
        self.format = format
 
32
        self.bzrdir = BzrDir.open_unsupported(url)
 
33
        if self.bzrdir.root_transport.is_readonly():
 
34
            raise errors.UpgradeReadonly
 
35
        self.transport = self.bzrdir.root_transport
 
36
        self.pb = ui.ui_factory.nested_progress_bar()
 
37
        try:
 
38
            self.convert()
 
39
        finally:
 
40
            self.pb.finished()
 
41
 
 
42
    def convert(self):
 
43
        try:
 
44
            branch = self.bzrdir.open_branch()
 
45
            if branch.bzrdir.root_transport.base != \
 
46
                self.bzrdir.root_transport.base:
 
47
                self.pb.note("This is a checkout. The branch (%s) needs to be "
 
48
                             "upgraded separately.",
 
49
                             branch.bzrdir.root_transport.base)
 
50
        except errors.NotBranchError:
 
51
            pass
 
52
        if not self.bzrdir.needs_format_conversion(self.format):
 
53
            raise errors.UpToDateFormat(self.bzrdir._format)
 
54
        if not self.bzrdir.can_convert_format():
 
55
            raise errors.BzrError("cannot upgrade from branch format %s" %
 
56
                           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)
 
62
        self.pb.note('starting upgrade of %s', self.transport.base)
 
63
        self._backup_control_dir()
 
64
        while self.bzrdir.needs_format_conversion(self.format):
 
65
            converter = self.bzrdir._format.get_converter(self.format)
 
66
            self.bzrdir = converter.convert(self.bzrdir, self.pb)
 
67
        self.pb.note("finished")
 
68
 
 
69
    def _backup_control_dir(self):
 
70
        self.pb.note('making backup of tree history')
 
71
        self.transport.copy_tree('.bzr', '.bzr.backup')
 
72
        self.pb.note('%s.bzr has been backed up to %s.bzr.backup',
 
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
 
 
78
def upgrade(url, format=None):
 
79
    """Upgrade to format, or the default bzrdir format if not supplied."""
 
80
    Convert(url, format)