Re: What's cooking in git/spearce.git (topics)

!MAILaRCHIVE_VOTE_RePLACE
Previous message: [thread] [date] [author]
Next message: [thread] [date] [author]
To: Shawn O. Pearce <spearce@...>
Cc: Linus Torvalds <torvalds@...>, <git@...>
Date: Monday, October 22, 2007 - 3:16 am

On Mon, Oct 22, 2007 at 02:32:22AM -0400, Shawn O. Pearce wrote:


Hrm, the problem is that it's not favoring basenames anymore. But I
think it is because the loop in find_identical_files is inside out. For
every source file, it picks the best destination file. But I think we
want to do the opposite: for every destination file, pick the best
source file. Otherwise, if a non-basename source file is connected with
a particular destination file, we no longer try that destination file
again.

Patch is below (please just squash with the one from Linus).

diff --git a/diffcore-rename.c b/diffcore-rename.c
index 05d39db..8881818 100644
--- a/diffcore-rename.c
+++ b/diffcore-rename.c
@@ -252,17 +252,18 @@ static int find_identical_files(struct file_similarity *src,
 {
 	int renames = 0;
 	do {
-		struct diff_filespec *one = src->filespec;
+		struct diff_filespec *one = dst->filespec;
 		struct file_similarity *p, *best;
 		int i = 100;
 
 		best = NULL;
-		for (p = dst; p; p = p->next) {
+		for (p = src; p; p = p->next) {
 			struct diff_filespec *two = p->filespec;
 
-			/* Already picked as a destination? */
+			/* Already picked as a source? */
 			if (!p->src_dst)
 				continue;
+
 			/* False hash collission? */
 			if (hashcmp(one->sha1, two->sha1))
 				continue;
@@ -276,10 +277,10 @@ static int find_identical_files(struct file_similarity *src,
 		}
 		if (best) {
 			best->src_dst = 0;
-			record_rename_pair(best->index, src->index, MAX_SCORE);
+			record_rename_pair(dst->index, best->index, MAX_SCORE);
 			renames++;
 		}
-	} while ((src = src->next) != NULL);
+	} while ((dst = dst->next) != NULL);
 	return renames;
 }
 
-
To unsubscribe from this list: send the line "unsubscribe git" in
the body of a message to majordomo@vger.kernel.org
More majordomo info at  http://vger.kernel.org/majordomo-info.html
Previous message: [thread] [date] [author]
Next message: [thread] [date] [author]

Messages in current thread:
What's cooking in git/spearce.git (topics), Shawn O. Pearce, (Mon Oct 22, 2:32 am)
What's cooking in git.git (topics), Junio C Hamano, (Wed Oct 24, 8:51 am)
What's cooking in git.git (topics), Junio C Hamano, (Thu Nov 1, 1:41 am)
What's cooking in git.git (topics), Junio C Hamano, (Sun Nov 4, 12:14 am)
What's cooking in git.git (topics), Junio C Hamano, (Thu Nov 8, 4:08 am)
What's cooking in git.git (topics), Junio C Hamano, (Mon Nov 12, 3:09 am)
What's cooking in git.git (topics), Junio C Hamano, (Wed Nov 14, 8:18 pm)
Re: What's cooking in git.git (topics), Jeff King, (Sat Nov 17, 8:40 am)
Re: What's cooking in git.git (topics), Johannes Schindelin, (Wed Nov 14, 8:49 pm)
[PATCH] t7501-commit: Add test for git commit &lt;file&gt; w..., Kristian Høgsberg, (Thu Nov 15, 10:49 am)
[PATCH] builtin-commit: fix "git add x y &amp;&amp; git comm..., Johannes Schindelin, (Thu Nov 15, 12:11 pm)
Re: [PATCH] builtin-commit: fix "git add x y &amp;&amp; git ..., Johannes Schindelin, (Thu Nov 15, 8:43 pm)
Re: [PATCH] builtin-commit: fix "git add x y &amp;&amp; git ..., Johannes Schindelin, (Thu Nov 15, 12:37 pm)
Re: [PATCH] t7501-commit: Add test for git commit &lt;file&g..., Johannes Schindelin, (Thu Nov 15, 11:55 am)
Re: What's cooking in git.git (topics), Johannes Schindelin, (Mon Nov 12, 8:21 am)
Re: What's cooking in git.git (topics), Steffen Prohaska, (Mon Nov 12, 10:27 am)
Re: What's cooking in git.git (topics), Johannes Schindelin, (Mon Nov 12, 11:02 am)
[PATCH 1/2] push: Add '--matching' option and print warning ..., Steffen Prohaska, (Sun Nov 18, 12:13 pm)
[PATCH 2/2] push: Add '--current', which pushes only the cur..., Steffen Prohaska, (Sun Nov 18, 12:13 pm)
[PATCH] push: Add "--current", which pushes only the current..., Steffen Prohaska, (Mon Nov 19, 12:51 pm)
Re: What's cooking in git.git (topics), Pierre Habouzit, (Mon Nov 12, 8:26 am)
Re: What's cooking in git.git (topics), Johannes Schindelin, (Mon Nov 12, 8:33 am)
Re: What's cooking in git.git (topics), Pierre Habouzit, (Mon Nov 12, 10:53 am)
[PATCH] rebase: brown paper bag fix after the detached HEAD ..., Johannes Schindelin, (Mon Nov 12, 9:11 am)
Re: What's cooking in git.git (topics), Steffen Prohaska, (Thu Nov 8, 4:44 pm)
Re: What's cooking in git.git (topics), Pierre Habouzit, (Sun Nov 4, 7:38 am)
Re: What's cooking in git.git (topics), Brian Downing, (Thu Nov 1, 5:41 pm)
Re: What's cooking in git.git (topics), Wincent Colaiuta, (Fri Nov 2, 6:26 am)
Re: What's cooking in git.git (topics), Pierre Habouzit, (Thu Nov 1, 5:46 pm)
Re: What's cooking in git.git (topics), Linus Torvalds, (Thu Nov 1, 2:33 pm)
Re: What's cooking in git.git (topics), Andreas Ericsson, (Fri Nov 2, 5:38 am)
Re: What's cooking in git.git (topics), Johannes Schindelin, (Fri Nov 2, 7:03 am)
Re: What's cooking in git.git (topics), Miles Bader, (Fri Nov 2, 2:06 am)
Re: What's cooking in git.git (topics), Miles Bader, (Fri Nov 2, 11:13 am)
Re: What's cooking in git.git (topics), Pierre Habouzit, (Thu Nov 1, 5:57 pm)
Re: What's cooking in git.git (topics), Geert Bosch, (Thu Nov 1, 3:19 pm)
Re: What's cooking in git.git (topics), Junio C Hamano, (Thu Nov 1, 4:27 pm)
Re: What's cooking in git.git (topics), Pierre Habouzit, (Thu Nov 1, 5:42 pm)
Re: What's cooking in git.git (topics), Andreas Ericsson, (Fri Nov 2, 5:39 am)
Re: What's cooking in git.git (topics), Johan Herland, (Thu Nov 1, 5:32 pm)
Re: What's cooking in git.git (topics), Junio C Hamano, (Thu Nov 1, 5:51 pm)
Re: What's cooking in git.git (topics), Linus Torvalds, (Thu Nov 1, 6:05 pm)
Re: What's cooking in git.git (topics), Petr Baudis, (Thu Nov 1, 10:19 pm)
Re: What's cooking in git.git (topics), Junio C Hamano, (Thu Nov 1, 6:50 pm)
Re: What's cooking in git.git (topics), Bill Lear, (Thu Nov 1, 6:26 pm)
Re: What's cooking in git.git (topics), Theodore Tso, (Thu Nov 1, 5:18 pm)
Re: What's cooking in git.git (topics), Melchior FRANZ, (Thu Nov 1, 5:26 pm)
Re: What's cooking in git.git (topics), Geert Bosch, (Thu Nov 1, 5:17 pm)
Re: What's cooking in git.git (topics), Jonas Fonseca, (Thu Nov 1, 8:00 pm)
Re: What's cooking in git.git (topics), Mike Hommey, (Thu Nov 1, 4:47 pm)
Re: What's cooking in git.git (topics), Pierre Habouzit, (Thu Nov 1, 5:44 pm)
Re: What's cooking in git.git (topics), Junio C Hamano, (Thu Nov 1, 5:20 pm)
Re: What's cooking in git.git (topics), Junio C Hamano, (Thu Nov 1, 8:32 pm)
Re: What's cooking in git.git (topics), Scott Parish, (Wed Oct 24, 12:08 pm)
Re: What's cooking in git.git (topics), Andreas Ericsson, (Wed Oct 24, 2:27 pm)
Re: What's cooking in git.git (topics), Scott Parish, (Wed Oct 24, 8:35 pm)
Re: What's cooking in git.git (topics), David Symonds, (Wed Oct 24, 9:09 am)
Re: What's cooking in git/spearce.git (topics), Junio C Hamano, (Mon Oct 22, 9:26 pm)
Re: What's cooking in git/spearce.git (topics), Shawn O. Pearce, (Mon Oct 22, 11:34 pm)
Re: What's cooking in git/spearce.git (topics), Steffen Prohaska, (Mon Oct 22, 11:27 am)
Re: What's cooking in git/spearce.git (topics), Pierre Habouzit, (Mon Oct 22, 3:24 am)
Re: What's cooking in git/spearce.git (topics), Jeff King, (Mon Oct 22, 3:16 am)
Re: What's cooking in git/spearce.git (topics), Linus Torvalds, (Mon Oct 22, 10:32 pm)
Re: What's cooking in git/spearce.git (topics), Jeff King, (Mon Oct 22, 11:48 pm)
Re: What's cooking in git/spearce.git (topics), Jeff King, (Mon Oct 22, 2:59 am)