remote-bzr: detect local repositories
So we don't create a clone unnecessarily. Signed-off-by: Felipe Contreras <felipe.contreras@gmail.com> Signed-off-by: Junio C Hamano <gitster@pobox.com>
This commit is contained in:
parent
570e7ecd4a
commit
073c3ffa58
@ -24,6 +24,7 @@ import bzrlib.plugin
|
|||||||
bzrlib.plugin.load_plugins()
|
bzrlib.plugin.load_plugins()
|
||||||
|
|
||||||
import bzrlib.generate_ids
|
import bzrlib.generate_ids
|
||||||
|
import bzrlib.transport
|
||||||
|
|
||||||
import sys
|
import sys
|
||||||
import os
|
import os
|
||||||
@ -613,11 +614,14 @@ def do_export(parser):
|
|||||||
if ref == 'refs/heads/master':
|
if ref == 'refs/heads/master':
|
||||||
repo.generate_revision_history(revid, marks.get_tip('master'))
|
repo.generate_revision_history(revid, marks.get_tip('master'))
|
||||||
revno, revid = repo.last_revision_info()
|
revno, revid = repo.last_revision_info()
|
||||||
if hasattr(peer, "import_last_revision_info_and_tags"):
|
if peer:
|
||||||
peer.import_last_revision_info_and_tags(repo, revno, revid)
|
if hasattr(peer, "import_last_revision_info_and_tags"):
|
||||||
|
peer.import_last_revision_info_and_tags(repo, revno, revid)
|
||||||
|
else:
|
||||||
|
peer.import_last_revision_info(repo.repository, revno, revid)
|
||||||
|
wt = peer.bzrdir.open_workingtree()
|
||||||
else:
|
else:
|
||||||
peer.import_last_revision_info(repo.repository, revno, revid)
|
wt = repo.bzrdir.open_workingtree()
|
||||||
wt = peer.bzrdir.open_workingtree()
|
|
||||||
wt.update()
|
wt.update()
|
||||||
print "ok %s" % ref
|
print "ok %s" % ref
|
||||||
print
|
print
|
||||||
@ -649,24 +653,28 @@ def do_list(parser):
|
|||||||
def get_repo(url, alias):
|
def get_repo(url, alias):
|
||||||
global dirname, peer
|
global dirname, peer
|
||||||
|
|
||||||
clone_path = os.path.join(dirname, 'clone')
|
|
||||||
origin = bzrlib.bzrdir.BzrDir.open(url)
|
origin = bzrlib.bzrdir.BzrDir.open(url)
|
||||||
remote_branch = origin.open_branch()
|
branch = origin.open_branch()
|
||||||
|
|
||||||
if os.path.exists(clone_path):
|
if not isinstance(origin.transport, bzrlib.transport.local.LocalTransport):
|
||||||
# pull
|
clone_path = os.path.join(dirname, 'clone')
|
||||||
d = bzrlib.bzrdir.BzrDir.open(clone_path)
|
remote_branch = branch
|
||||||
branch = d.open_branch()
|
if os.path.exists(clone_path):
|
||||||
result = branch.pull(remote_branch, [], None, False)
|
# pull
|
||||||
|
d = bzrlib.bzrdir.BzrDir.open(clone_path)
|
||||||
|
branch = d.open_branch()
|
||||||
|
result = branch.pull(remote_branch, [], None, False)
|
||||||
|
else:
|
||||||
|
# clone
|
||||||
|
d = origin.sprout(clone_path, None,
|
||||||
|
hardlink=True, create_tree_if_local=False,
|
||||||
|
source_branch=remote_branch)
|
||||||
|
branch = d.open_branch()
|
||||||
|
branch.bind(remote_branch)
|
||||||
|
|
||||||
|
peer = remote_branch
|
||||||
else:
|
else:
|
||||||
# clone
|
peer = None
|
||||||
d = origin.sprout(clone_path, None,
|
|
||||||
hardlink=True, create_tree_if_local=False,
|
|
||||||
source_branch=remote_branch)
|
|
||||||
branch = d.open_branch()
|
|
||||||
branch.bind(remote_branch)
|
|
||||||
|
|
||||||
peer = remote_branch
|
|
||||||
|
|
||||||
return branch
|
return branch
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user