]> granicus.if.org Git - git/commit
Bypass expensive content comparsion during rename detection.
authorShawn O. Pearce <spearce@spearce.org>
Thu, 14 Dec 2006 10:07:46 +0000 (05:07 -0500)
committerJunio C Hamano <junkio@cox.net>
Thu, 14 Dec 2006 10:40:33 +0000 (02:40 -0800)
commit7da41f48c8acea834e8204917fe59da2b975903b
tree4a07966ead29f783b0350a51c4c5c6338910f176
parent155bd0ce23144e5c7067965a22646523f1a38b51
Bypass expensive content comparsion during rename detection.

When comparing file contents during the second loop through a rename
detection attempt we can skip the expensive byte-by-byte comparsion
if both source and destination files have valid SHA1 values.  This
improves performance by avoiding either an expensive open/mmap to
read the working tree copy, or an expensive inflate of a blob object.

Unfortunately we still have to at least initialize the sizes of the
source and destination files even if the SHA1 values don't match.
Failing to initialize the sizes causes a number of test cases to fail
and start reporting different copy/rename behavior than was expected.

Signed-off-by: Shawn O. Pearce <spearce@spearce.org>
Signed-off-by: Junio C Hamano <junkio@cox.net>
diffcore-rename.c