17
17
from cStringIO import StringIO
19
from bzrlib.symbol_versioning import deprecated_function, deprecated_in
19
20
from bzrlib.lazy_import import lazy_import
20
21
lazy_import(globals(), """
21
22
from bzrlib import (
23
transport as _mod_transport,
26
26
from bzrlib.bundle import serializer as _serializer
27
27
from bzrlib.merge_directive import MergeDirective
28
from bzrlib.i18n import gettext
28
from bzrlib.transport import (
29
do_catching_redirections,
30
33
from bzrlib.trace import note
36
@deprecated_function(deprecated_in((1, 12, 0)))
37
def read_bundle_from_url(url):
38
return read_mergeable_from_url(url, _do_directive=False)
33
41
def read_mergeable_from_url(url, _do_directive=True, possible_transports=None):
34
42
"""Read mergable object from a given URL.
36
44
:return: An object supporting get_target_revision. Raises NotABundle if
37
45
the target is not a mergeable type.
39
child_transport = _mod_transport.get_transport(url,
47
child_transport = get_transport(url,
40
48
possible_transports=possible_transports)
41
49
transport = child_transport.clone('..')
42
50
filename = transport.relpath(child_transport.base)
54
62
url, filename = urlutils.split(exception.target,
55
63
exclude_trailing_slash=False)
57
raise errors.NotABundle(gettext('A directory cannot be a bundle'))
58
return _mod_transport.get_transport_from_url(url)
65
raise errors.NotABundle('A directory cannot be a bundle')
66
return get_transport(url)
61
bytef, transport = _mod_transport.do_catching_redirections(
62
get_bundle, transport, redirected_transport)
69
bytef, transport = do_catching_redirections(get_bundle, transport,
63
71
except errors.TooManyRedirections:
64
72
raise errors.NotABundle(transport.clone(filename).base)
65
73
except (errors.ConnectionReset, errors.ConnectionError), e: