OSDN Git Service

am --skip/--abort: merge HEAD/ORIG_HEAD tree into index
authorJohannes Schindelin <johannes.schindelin@gmx.de>
Wed, 9 Sep 2015 09:10:07 +0000 (09:10 +0000)
committerJunio C Hamano <gitster@pobox.com>
Wed, 9 Sep 2015 21:22:56 +0000 (14:22 -0700)
f8da6801 (am --skip: support skipping while on unborn branch,
2015-06-06) introduced a performance regression to "git am --skip",
where it used "read-tree" to reconstruct the index from scratch
without reusing the cached stat information.

This is a backport of the corresponding patch to the builtin am in 2.6:
3ecc704 (am --skip/--abort: merge HEAD/ORIG_HEAD tree into index,
2015-08-19).

Reportedly, it can make a huge difference on Windows, in one case a `git
rebase --skip` took 1m40s without, and 5s with, this patch.

cf. https://github.com/git-for-windows/git/issues/365

Reported-and-suggested-by: Kim Gybels <kgybels@infogroep.be>
Acked-by: Paul Tan <pyokagan@gmail.com>
Signed-off-by: Johannes Schindelin <johannes.schindelin@gmx.de>
Signed-off-by: Junio C Hamano <gitster@pobox.com>
git-am.sh

index 3103c0f..4ab1f21 100755 (executable)
--- a/git-am.sh
+++ b/git-am.sh
@@ -509,7 +509,7 @@ then
                git read-tree --reset -u $head_tree $head_tree &&
                index_tree=$(git write-tree) &&
                git read-tree -m -u $index_tree $head_tree
-               git read-tree $head_tree
+               git read-tree -m $head_tree
                ;;
        ,t)
                if test -f "$dotest/rebasing"