Re: seperate commits for objects already updated in index?

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



On Tue, 14 Mar 2006, Junio C Hamano wrote:

<snip - interesting, thanks>

It might be better to further check if the working tree file is the same as the index, and to allow a commit in such a case.

That would be a nice improvement.

The intent of rule #2 is to prevent this from happening:

	$ edit A B
       $ git update-index A B
       $ edit B again
       $ git commit -o B

When this happens, the real index will have _old_ contents of B that never was committed, and does not match what is in the index. But after the commit, we will match the real index to what was committed, so we will _lose_ the index entry for B before the second edit you explicitly told git to remember by saying 'update-index'.

That would indeed be annoying, and I'd obviously prefer to have to run 'git reset' than have the above happen!

However, I'd have expected that any porcelain command would synchronise index with HEAD after a commit. See below for my (still newbie-ish ;) ) user-level mental model of git.

On the other hand, in your original sequence:

	$ edit A B
       $ git update-index A B
       $ git commit -o B

B being committed would be different between HEAD and index, but that is what we are going to commit anyway, so after this commit, B will be in sync with the updated HEAD.

Right. So if the file in the index and working tree are the same (hey, i just ran update-index after all), then that check could be loosened. The only thing the commit can do is bring the /3rd/ piece of the puzzle (HEAD) in sync :).

To put it in another way, "commit -o" is a short-hand for people who do not want to run update-index themselves (IOW, people who just want to use git without worrying about the index file). If you use update-index to mark "this is what I want to commit" yourself, you should do so consistently. If you are not ready to commit A but you want to commit B, do not mark both of them and expect "commit -o" to do magic fixups.

I guess my problem here is that I consider the index to be a 'weak' cache.

I like to use it for intermediate way-points or "weak commits", however if I commit to HEAD I /really/ want what (I consider to be) the two /strong/ sources of file information (HEAD and working file) to be synchronised, and the 'weak' cache updated then to match.

I wasn't expecting the 'weak' cache of the index to prevent me synchronising my 'strong' sources (HEAD and working file). I was expecting the 'weak' cache to be updated to the 'strong' ones.

If I want to synchronise this 'weak' cache, I'll do so explicitely (though, there isn't a user-obvious distinction in commands for this, there's no obvious "git-commit-index"). Maybe part of the problem here is that git-commit tries to hide the index/working-tree/HEAD distinction? I don't know.

Anyway, if git-commit can lift "Rule 2" where file in working tree and index match, that'd be great - but I can easily live with git-reset till then. ;)

Thanks for the informative email!

regards,
--
Paul Jakma	paul@xxxxxxxx	paul@xxxxxxxxx	Key ID: 64A2FF6A
Fortune:
A violent man will die a violent death.
		-- Lao Tsu
-
: 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

[Index of Archives]     [Linux Kernel Development]     [Gcc Help]     [IETF Annouce]     [DCCP]     [Netdev]     [Networking]     [Security]     [V4L]     [Bugtraq]     [Yosemite]     [MIPS Linux]     [ARM Linux]     [Linux Security]     [Linux RAID]     [Linux SCSI]     [Fedora Users]