# HG changeset patch # User Pierre-Yves David # Date 2014-01-08 22:53:46 # Node ID 2123d27ff75d551996a3e449e4da80e5ff7db5d1 # Parent 7a259dfe24f78ccdc62a91e72580e3e5f86280e9 backout: avoid update on simple case. Before the changeset the backout process was: 1) go to 2) revert to parent 3) update back to changeset we came from The two update steps can takes a very long time to move back and forth unrelated file change between and current working directory. The new process is just merging current working directory with the parent of using as ancestor. This give the very same result but skip the two updates. On big repo with a lot of files and changes that save a lots of time (x20 for one week window). The "merge" version (hg backout --merge) is still done with upgrades. We could imagine using in memory commit to speed it up but this is another fish. diff --git a/mercurial/commands.py b/mercurial/commands.py --- a/mercurial/commands.py +++ b/mercurial/commands.py @@ -461,16 +461,23 @@ def backout(ui, repo, node=None, rev=Non try: branch = repo.dirstate.branch() bheads = repo.branchheads(branch) - hg.clean(repo, node, show_stats=False) - repo.dirstate.setbranch(branch) rctx = scmutil.revsingle(repo, hex(parent)) - cmdutil.revert(ui, repo, rctx, repo.dirstate.parents()) if not opts.get('merge') and op1 != node: try: ui.setconfig('ui', 'forcemerge', opts.get('tool', '')) - return hg.update(repo, op1) + stats = mergemod.update(repo, parent, True, True, False, node, False) + repo.setparents(op1, op2) + hg._showstats(repo, stats) + if stats[3]: + repo.ui.status(_("use 'hg resolve' to retry unresolved file merges\n")) + return stats[3] > 0 finally: ui.setconfig('ui', 'forcemerge', '') + else: + hg.clean(repo, node, show_stats=False) + repo.dirstate.setbranch(branch) + cmdutil.revert(ui, repo, rctx, repo.dirstate.parents()) + e = cmdutil.commiteditor if not opts['message'] and not opts['logfile']: diff --git a/tests/test-backout.t b/tests/test-backout.t --- a/tests/test-backout.t +++ b/tests/test-backout.t @@ -188,7 +188,6 @@ backout should not back out subsequent c without --merge $ hg backout -d '3 0' 1 --tool=true - reverting a 1 files updated, 0 files merged, 0 files removed, 0 files unresolved $ hg locate b b @@ -324,8 +323,7 @@ named branches without --merge $ hg backout -r 1 --tool=true - removing file1 - 1 files updated, 0 files merged, 0 files removed, 0 files unresolved + 0 files updated, 0 files merged, 1 files removed, 0 files unresolved $ hg branch branch2 $ hg status -A diff --git a/tests/test-subrepo.t b/tests/test-subrepo.t --- a/tests/test-subrepo.t +++ b/tests/test-subrepo.t @@ -468,11 +468,6 @@ backout calls revert internally with min KeyError $ hg backout ".^" - reverting .hgsubstate - reverting subrepo s - reverting s/a (glob) - reverting subrepo ss - reverting subrepo t 0 files updated, 0 files merged, 0 files removed, 0 files unresolved $ hg up -C # discard changes