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.transport import (
29
do_catching_redirections,
29
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)
32
41
def read_mergeable_from_url(url, _do_directive=True, possible_transports=None):
33
42
"""Read mergable object from a given URL.
35
44
:return: An object supporting get_target_revision. Raises NotABundle if
36
45
the target is not a mergeable type.
38
child_transport = _mod_transport.get_transport(url,
47
child_transport = get_transport(url,
39
48
possible_transports=possible_transports)
40
49
transport = child_transport.clone('..')
41
50
filename = transport.relpath(child_transport.base)
54
63
exclude_trailing_slash=False)
56
65
raise errors.NotABundle('A directory cannot be a bundle')
57
return _mod_transport.get_transport_from_url(url)
66
return get_transport(url)
60
bytef, transport = _mod_transport.do_catching_redirections(
61
get_bundle, transport, redirected_transport)
69
bytef, transport = do_catching_redirections(get_bundle, transport,
62
71
except errors.TooManyRedirections:
63
72
raise errors.NotABundle(transport.clone(filename).base)
64
73
except (errors.ConnectionReset, errors.ConnectionError), e: