On Monday 2007, March 19, Steven Grimm wrote: > On the other hand, I agree with your general point; I really don't > like being uncertain about whether renames are going to come out > correctly or not ("it has always worked before" and "it is by design I agree with you, but I think that git does exactly what you want. In fact I think git is better. The beauty of git figuring out renames for itself is that git can figure it out later. $ mv file1 file2 $ git update-index --remove file1 $ git add file2 The important thing here is that git wasn't used to do the move. This is great when you're lost in a development haze and do the move without thinking. > So to answer your question, in my opinion if 100% guaranteed renames > are high on your priority list, then Mercurial might be the better > option for now. In practice, I've found that git's 99+% rename > detection has yet to fail on me aside from the above directory > renaming case, but at the end of the day it *is* guessing at your > renames after the fact. It's not really a guess; through the magic of sha-1, and provided you are disciplined enough to commit the rename without any changes to the content you can be sure that the rename is tracked. The sha-1 /must/ be the same before and after. For this 100% case, git doesn't even need the "-M", git-blame, git-diff and git-merge will find it anyway. Even better is that because the rename isn't recorded explicitly when you upgrade git and the detection gets better, all your history instantly gets interpreted correctly. The only command I've found that doesn't do the "right thing" by default is git-log and I think that once the following works, all the "why doesn't git track renames" people will go quietly away: $ git init $ date > file1 $ git add file1 $ git commit -m "" $ git mv file1 file2 $ git commit -m "" $ git mv file2 file3 $ git commit -m "" $ git log -- file3 Andy -- Dr Andy Parkins, M Eng (hons), MIET andyparkins@xxxxxxxxx - To unsubscribe from this list: send the line "unsubscribe git" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html