diff options
author | Andrew Ng <andrew.ng@sony.com> | 2020-05-19 14:05:35 +0100 |
---|---|---|
committer | Junio C Hamano <gitster@pobox.com> | 2020-05-19 15:35:46 -0700 |
commit | 8777616e4db2868609bc42a4c66cc69d23532dbc (patch) | |
tree | 2bf472dd0563ed2c98c8420f0aa8e7fb02738275 /builtin/merge.c | |
parent | Git 2.26.2 (diff) | |
download | tgif-8777616e4db2868609bc42a4c66cc69d23532dbc.tar.xz |
merge: optimization to skip evaluate_result for single strategy
For a merge with a single strategy, the result of evaluate_result() is
effectively not used and therefore is not needed, so avoid altogether.
On Windows, this optimization can halve the time required to perform a
recursive merge of a single commit with the LLVM repo.
Signed-off-by: Andrew Ng <andrew.ng@sony.com>
Signed-off-by: Junio C Hamano <gitster@pobox.com>
Diffstat (limited to 'builtin/merge.c')
-rw-r--r-- | builtin/merge.c | 2 |
1 files changed, 1 insertions, 1 deletions
diff --git a/builtin/merge.c b/builtin/merge.c index d127d2225f..826e2c2656 100644 --- a/builtin/merge.c +++ b/builtin/merge.c @@ -1629,7 +1629,7 @@ int cmd_merge(int argc, const char **argv, const char *prefix) } merge_was_ok = 1; } - cnt = evaluate_result(); + cnt = (use_strategies_nr > 1) ? evaluate_result() : 0; if (best_cnt <= 0 || cnt <= best_cnt) { best_strategy = use_strategies[i]->name; best_cnt = cnt; |