diff options
author | Felipe Contreras <felipe.contreras@gmail.com> | 2013-05-25 04:30:04 +0200 |
---|---|---|
committer | Junio C Hamano <gitster@pobox.com> | 2013-05-28 17:02:25 +0200 |
commit | c9eaef125bbecd60a8b328d58e66306d5db1357a (patch) | |
tree | c6444803cf4188a4f6502c7192b3299ad8e2f186 /contrib/remote-helpers/git-remote-hg | |
parent | remote-hg: add support for --dry-run (diff) | |
download | git-c9eaef125bbecd60a8b328d58e66306d5db1357a.tar.xz git-c9eaef125bbecd60a8b328d58e66306d5db1357a.zip |
remote-hg: add support for --force
And get rid of the remote-hg.force-push option hack.
Signed-off-by: Felipe Contreras <felipe.contreras@gmail.com>
Signed-off-by: Junio C Hamano <gitster@pobox.com>
Diffstat (limited to 'contrib/remote-helpers/git-remote-hg')
-rwxr-xr-x | contrib/remote-helpers/git-remote-hg | 30 |
1 files changed, 17 insertions, 13 deletions
diff --git a/contrib/remote-helpers/git-remote-hg b/contrib/remote-helpers/git-remote-hg index 20abb34801..0194c67fb1 100755 --- a/contrib/remote-helpers/git-remote-hg +++ b/contrib/remote-helpers/git-remote-hg @@ -29,9 +29,6 @@ import urlparse, hashlib # named branches: # git config --global remote-hg.track-branches false # -# If you don't want to force pushes (and thus risk creating new remote heads): -# git config --global remote-hg.force-push false -# # If you want the equivalent of hg's clone/pull--insecure option: # git config --global remote-hg.insecure true # @@ -877,9 +874,6 @@ def write_tag(repo, tag, node, msg, author): return (tagnode, branch) def checkheads_bmark(repo, ref, ctx): - if force_push: - return True - bmark = ref[len('refs/heads/'):] if not bmark in bmarks: # new bmark @@ -888,8 +882,11 @@ def checkheads_bmark(repo, ref, ctx): ctx_old = bmarks[bmark] ctx_new = ctx if not repo.changelog.descendant(ctx_old.rev(), ctx_new.rev()): - print "error %s non-fast forward" % ref - return False + if force_push: + print "ok %s forced update" % ref + else: + print "error %s non-fast forward" % ref + return False return True @@ -936,8 +933,12 @@ def checkheads(repo, remote, p_revs): continue node = repo.changelog.node(rev) - print "error %s non-fast forward" % p_revs[node] - ret = False + ref = p_revs[node] + if force_push: + print "ok %s forced update" % ref + else: + print "error %s non-fast forward" % ref + ret = False return ret @@ -949,7 +950,7 @@ def push_unsafe(repo, remote, parsed_refs, p_revs): commoninc = fci(repo, remote, force=force) common, _, remoteheads = commoninc - if not force and not checkheads(repo, remote, p_revs): + if not checkheads(repo, remote, p_revs): return None cg = repo.getbundle('push', heads=list(p_revs), common=common) @@ -1110,11 +1111,14 @@ def do_export(parser): print def do_option(parser): - global dry_run + global dry_run, force_push _, key, value = parser.line.split(' ') if key == 'dry-run': dry_run = (value == 'true') print 'ok' + elif key == 'force': + force_push = (value == 'true') + print 'ok' else: print 'unsupported' @@ -1142,7 +1146,7 @@ def main(args): hg_git_compat = get_config_bool('remote-hg.hg-git-compat') track_branches = get_config_bool('remote-hg.track-branches', True) - force_push = get_config_bool('remote-hg.force-push') + force_push = False if hg_git_compat: mode = 'hg' |