remote-bzr: add support for remote repositories
Strictly speaking bzr doesn't need any changes to interact with remote repositories, but it's dead slow. Signed-off-by: Felipe Contreras <felipe.contreras@gmail.com> Signed-off-by: Junio C Hamano <gitster@pobox.com>
This commit is contained in:
parent
f04977168f
commit
dc2177c21c
@ -546,7 +546,7 @@ def parse_reset(parser):
|
|||||||
parsed_refs[ref] = mark_to_rev(from_mark)
|
parsed_refs[ref] = mark_to_rev(from_mark)
|
||||||
|
|
||||||
def do_export(parser):
|
def do_export(parser):
|
||||||
global parsed_refs, dirname
|
global parsed_refs, dirname, peer
|
||||||
|
|
||||||
parser.next()
|
parser.next()
|
||||||
|
|
||||||
@ -569,6 +569,8 @@ def do_export(parser):
|
|||||||
for ref, revid in parsed_refs.iteritems():
|
for ref, revid in parsed_refs.iteritems():
|
||||||
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()
|
||||||
|
peer.import_last_revision_info_and_tags(repo, revno, revid)
|
||||||
print "ok %s" % ref
|
print "ok %s" % ref
|
||||||
print
|
print
|
||||||
|
|
||||||
@ -597,8 +599,28 @@ def do_list(parser):
|
|||||||
print
|
print
|
||||||
|
|
||||||
def get_repo(url, alias):
|
def get_repo(url, alias):
|
||||||
|
global dirname, peer
|
||||||
|
|
||||||
|
clone_path = os.path.join(dirname, 'clone')
|
||||||
origin = bzrlib.controldir.ControlDir.open(url)
|
origin = bzrlib.controldir.ControlDir.open(url)
|
||||||
return origin.open_branch()
|
remote_branch = origin.open_branch()
|
||||||
|
|
||||||
|
if os.path.exists(clone_path):
|
||||||
|
# pull
|
||||||
|
d = bzrlib.controldir.ControlDir.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
|
||||||
|
|
||||||
|
return branch
|
||||||
|
|
||||||
def main(args):
|
def main(args):
|
||||||
global marks, prefix, dirname
|
global marks, prefix, dirname
|
||||||
|
Loading…
Reference in New Issue
Block a user