summaryrefslogtreecommitdiffstats
path: root/diffcore-rename.c
diff options
context:
space:
mode:
authorJunio C Hamano <junkio@cox.net>2005-11-21 21:18:23 +0100
committerJunio C Hamano <junkio@cox.net>2005-11-21 21:21:24 +0100
commit9f70b806920e3ea158d7e189a1ec668445c13359 (patch)
tree0de8fc57e0e221f5588f895eb161faee5acc9e7d /diffcore-rename.c
parentformat-patch: fix two-argument special case, and make it easier to pick singl... (diff)
downloadgit-9f70b806920e3ea158d7e189a1ec668445c13359.tar.xz
git-9f70b806920e3ea158d7e189a1ec668445c13359.zip
rename detection with -M100 means "exact renames only".
When the user is interested in pure renames, there is no point doing the similarity scores. This changes the score argument parsing to special case -M100 (otherwise, it is a precision scaled value 0 <= v < 1 and would mean 0.1, not 1.0 --- if you do mean 0.1, you can say -M1), and optimizes the diffcore_rename transformation to only look at pure renames in that case. Signed-off-by: Junio C Hamano <junkio@cox.net>
Diffstat (limited to 'diffcore-rename.c')
-rw-r--r--diffcore-rename.c3
1 files changed, 3 insertions, 0 deletions
diff --git a/diffcore-rename.c b/diffcore-rename.c
index 6a9d95d059..dba965c0b4 100644
--- a/diffcore-rename.c
+++ b/diffcore-rename.c
@@ -307,6 +307,9 @@ void diffcore_rename(struct diff_options *options)
if (rename_count == rename_dst_nr)
goto cleanup;
+ if (minimum_score == MAX_SCORE)
+ goto cleanup;
+
num_create = (rename_dst_nr - rename_count);
num_src = rename_src_nr;
mx = xmalloc(sizeof(*mx) * num_create * num_src);