14
14
# along with this program; if not, write to the Free Software
15
15
# Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
17
from __future__ import absolute_import
19
17
from cStringIO import StringIO
19
from bzrlib.symbol_versioning import deprecated_function, deprecated_in
21
20
from bzrlib.lazy_import import lazy_import
22
21
lazy_import(globals(), """
23
22
from bzrlib import (
25
transport as _mod_transport,
28
26
from bzrlib.bundle import serializer as _serializer
29
27
from bzrlib.merge_directive import MergeDirective
30
from bzrlib.i18n import gettext
28
from bzrlib.transport import (
29
do_catching_redirections,
32
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)
35
41
def read_mergeable_from_url(url, _do_directive=True, possible_transports=None):
36
42
"""Read mergable object from a given URL.
38
44
:return: An object supporting get_target_revision. Raises NotABundle if
39
45
the target is not a mergeable type.
41
child_transport = _mod_transport.get_transport(url,
47
child_transport = get_transport(url,
42
48
possible_transports=possible_transports)
43
49
transport = child_transport.clone('..')
44
50
filename = transport.relpath(child_transport.base)
56
62
url, filename = urlutils.split(exception.target,
57
63
exclude_trailing_slash=False)
59
raise errors.NotABundle(gettext('A directory cannot be a bundle'))
60
return _mod_transport.get_transport_from_url(url)
65
raise errors.NotABundle('A directory cannot be a bundle')
66
return get_transport(url)
63
bytef, transport = _mod_transport.do_catching_redirections(
64
get_bundle, transport, redirected_transport)
69
bytef, transport = do_catching_redirections(get_bundle, transport,
65
71
except errors.TooManyRedirections:
66
72
raise errors.NotABundle(transport.clone(filename).base)
67
73
except (errors.ConnectionReset, errors.ConnectionError), e: