On Thu, 30 Nov 2006, Linus Torvalds wrote:I'm not sure I want to see the whole added file more when diffing two trees, or when I do "git diff --cached" after "git update-index --add", than when I do "git diff" after "git add", but I'll concede that viewing the content of a new file as a diff is no fun. (Maybe diff-against-nothing for display needs work in general? It's solve the whole root commit thing, too.) This is where I think "git add" is really broken. For every other git command, if the command causes the index to not match HEAD, the command contains "index" either in the name of the command or in an option. So, if you understand the index, and you understand git's model, but you don't know this one weird corner case, you will come to the conclusion that "git add <path>" leaves <path> such that the index matches HEAD. Now *you* know that "git add" really is "git update-index --add", because you were typing the latter (well, "git update-cache --add", anyway) before "git add" existed at all. But for new users, and anyone who wasn't adding a lot of files back then, it's a surprising exception that has to be learned and internalized. "git checkout" leaves the index matching HEAD or its original state. "git commit" leaves the index matching HEAD (the new HEAD) or its original state. "git reset" (all options) leaves the index matching HEAD or its original state. "git pull/merge" does disrupt the index, but it also starts to prepare a commit based on multiple *HEAD files, and it leaves every stage of the index matching some *HEAD or its original state. And new users still seem to wonder where the merge happens, because it doesn't say "in the index". "git apply" leaves the index alone. "git update-index" says it works on the index. "git apply --index" says it works on the index. Am I missing any violations of the rule? I guess "git rm", but that's just for the CVS-damaged, unnecessary anyway, and it still doesn't care about the state of the working directory at any particular point in time. And I still prefer "git update-index --force-remove" as a command for that operation. So it's obvious that the "add" functionality is properly called "git add --index", because whatever "git add" would, it would have to leave the index matching HEAD or its original state. (Well, okay, '"git commit -i path" ^C', violates the rule. But I forgot until recently that -i stands for --include, not --index, which would make a reasonable expansion, too) I think people's model is likely to be closer to "touch" for the index, especially since it has no effect if the file is already in the index. "git add" doesn't *say* it changes the index, and nothing else there *says* it changes the index, so "git commit" there should say "nothing to commit", because you never did "git update-index file", either before or after the change, and you didn't do "git commit file" or "git commit -a". Just tossing the words in commands around, it's obvious that what "git add file" should do is mean that you can now do "git update-index file" instead of "git update-index --add file". Saying you shouldn't need "update-index" after adding a file is like saying you shouldn't need "update-index" after modifying a file. But it shouldn't change my index any more than "git apply" should, because it doesn't say it updates the index. (Of course, it would be good to have "git add --index file", matching "git apply --index patch", which does what "git add" does now.) Now, in order to interact correctly with reseting, checking out a different branch, etc, it wants to have the information in the index file, so there isn't a separate file with a list to lose stuff from. And it patterns naturally as an adjunct to the index for some things (like ls-files, which doesn't care at all what the content associated with filenames is). But that's fundamentally an implementation detail, not an aspect of the model. -Daniel *This .sig left intentionally blank* - 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
| jjohansen | [AppArmor 39/45] AppArmor: Profile loading and manipulation, pathname matching |
| Vladislav Bolkhovitin | Re: Integration of SCST in the mainstream Linux kernel |
| Heiko Carstens | Re: -mm merge plans for 2.6.23 -- sys_fallocate |
| Andrew Morton | 2.6.23-rc6-mm1 |
git: | |
| Gerrit Renker | [PATCH 27/37] dccp: Integration of dynamic feature activation - part 2 (server side) |
| Evgeniy Polyakov | Re: [BUG] New Kernel Bugs |
| Jarek Poplawski | [PATCH] pkt_sched: Destroy gen estimators under rtnl_lock(). |
| David Miller | [GIT]: Networking |
