diff options
| author | Junio C Hamano <junkio@cox.net> | 2005-05-30 00:08:07 -0700 | 
|---|---|---|
| committer | Linus Torvalds <torvalds@ppc970.osdl.org> | 2005-05-30 10:35:49 -0700 | 
| commit | 2cd68882ee8629f9782be017007fff4c78e45e45 (patch) | |
| tree | 8a0c8a7ec9671d06cb33bb4d91596ddb9877b961 /diffcore-rename.c | |
| parent | 9d429ff6ff2832d6e63933e6d33b8380be703017 (diff) | |
| download | git-2cd68882ee8629f9782be017007fff4c78e45e45.tar.gz | |
[PATCH] diff: fix the culling of unneeded delete record.
The commit 15d061b435a7e3b6bead39df3889f4af78c4b00a
    [PATCH] Fix the way diffcore-rename records unremoved source.
still leaves unneeded delete records in its output stream by
mistake, which was covered up by having an extra check to turn
such a delete into a no-op downstream.  Fix the check in the
diffcore-rename to simplify the output routine.
Signed-off-by: Junio C Hamano <junkio@cox.net>
Signed-off-by: Linus Torvalds <torvalds@osdl.org>
Diffstat (limited to 'diffcore-rename.c')
| -rw-r--r-- | diffcore-rename.c | 44 | 
1 files changed, 33 insertions, 11 deletions
| diff --git a/diffcore-rename.c b/diffcore-rename.c index cf3fe09323..6ed8cf5aec 100644 --- a/diffcore-rename.c +++ b/diffcore-rename.c @@ -328,26 +328,48 @@ void diffcore_rename(int detect_rename, int minimum_score)  	outq.nr = outq.alloc = 0;  	for (i = 0; i < q->nr; i++) {  		struct diff_filepair *p = q->queue[i]; -		struct diff_rename_dst *dst = locate_rename_dst(p->two, 0);  		struct diff_filepair *pair_to_free = NULL; -		if (dst) { -			/* creation */ -			if (dst->pair) { -				/* renq has rename/copy to produce -				 * this file already, so we do not -				 * emit the creation record in the -				 * output. -				 */ +		if (!DIFF_FILE_VALID(p->one) && DIFF_FILE_VALID(p->two)) { +			/* +			 * Creation +			 * +			 * We would output this create record if it has +			 * not been turned into a rename/copy already. +			 */ +			struct diff_rename_dst *dst = +				locate_rename_dst(p->two, 0); +			if (dst && dst->pair) {  				diff_q(&outq, dst->pair);  				pair_to_free = p;  			}  			else -				/* no matching rename/copy source, so record -				 * this as a creation. +				/* no matching rename/copy source, so +				 * record this as a creation.  				 */  				diff_q(&outq, p);  		} +		else if (DIFF_FILE_VALID(p->one) && !DIFF_FILE_VALID(p->two)) { +			/* +			 * Deletion +			 * +			 * We would output this delete record if renq +			 * does not have a rename/copy to move +			 * p->one->path out. +			 */ +			for (j = 0; j < renq.nr; j++) +				if (!strcmp(renq.queue[j]->one->path, +					    p->one->path)) +					break; +			if (j < renq.nr) +				/* this path remains */ +				pair_to_free = p; + +			if (pair_to_free) +				; +			else +				diff_q(&outq, p); +		}  		else if (!diff_unmodified_pair(p))  			/* all the usual ones need to be kept */  			diff_q(&outq, p); | 
