From: Paul Jakma <paul@clubi.ie>
To: Junio C Hamano <junkio@cox.net>
Cc: git@vger.kernel.org, Linus Torvalds <torvalds@osdl.org>
Subject: Re: seperate commits for objects already updated in index?
Date: Wed, 15 Mar 2006 13:28:48 +0000 (GMT) [thread overview]
Message-ID: <Pine.LNX.4.64.0603151312030.5276@sheen.jakma.org> (raw)
In-Reply-To: <7vy7zcie5c.fsf@assigned-by-dhcp.cox.net>
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@clubi.ie paul@jakma.org Key ID: 64A2FF6A
Fortune:
A violent man will die a violent death.
-- Lao Tsu
next prev parent reply other threads:[~2006-03-15 13:31 UTC|newest]
Thread overview: 11+ messages / expand[flat|nested] mbox.gz Atom feed top
2006-03-14 16:37 seperate commits for objects already updated in index? Paul Jakma
2006-03-14 17:00 ` Linus Torvalds
2006-03-14 17:04 ` Paul Jakma
2006-03-14 17:20 ` Linus Torvalds
2006-03-14 17:27 ` Paul Jakma
2006-03-14 23:51 ` Junio C Hamano
2006-03-15 3:24 ` Junio C Hamano
2006-03-15 13:28 ` Paul Jakma [this message]
2006-03-15 14:00 ` Andreas Ericsson
2006-03-15 19:25 ` Junio C Hamano
2006-03-15 19:43 ` Andreas Ericsson
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=Pine.LNX.4.64.0603151312030.5276@sheen.jakma.org \
--to=paul@clubi.ie \
--cc=git@vger.kernel.org \
--cc=junkio@cox.net \
--cc=torvalds@osdl.org \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).