Re: On writing builtin-reset.c, a question about git-reset.sh

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

 



Carlos Rica <jasampler@xxxxxxxxx> writes:

> Hi, I'm writing builtin-reset.c and
> I'm really stuck with a little code in
> git-reset.sh:
>
> if orig=$(git rev-parse --verify HEAD 2>/dev/null)
> then
> 	echo "$orig" >"$GIT_DIR/ORIG_HEAD"
> else
> 	rm -f "$GIT_DIR/ORIG_HEAD"
> fi
>
> My question is about when this condition
> could fail (and then the rm executed),...

When orig does not exist.  That is, when HEAD is a symref that
point at an unborn branch (e.g. between "git init" and your
first "git commit").  After "git reset" of any kind, we would
want to make sure that GIT_DIR/ORIG_HEAD points at the commit
you were previously at, and if orig is not there we do not want
anything in that file.

Another possibility would be if somebody wants to add an
unrelated branch to the repository [*1*].  This is against
recommended practice, but you could make your HEAD point at an
unborn branch using plumbing commands, or even by hand:

	$ echo 'ref: refs/heads/unrelated' >.git/HEAD

Your next commit will make a root commit that is pointed by
'refs/heads/unrelated' ref, but before that happens, we would
not want to have GIT_DIR/ORIG_HEAD if you did git-reset.

Now, you might wonder if "git reset" makes any sense from such a
state, and actually it does ;-)

	$ git init
        $ git remote add -f friend ../neighbour.git/
        $ git reset --hard friend/master

[Footnote]

*1* People often seem to want to do something like the html, man, and
todo branches in my public repository that do not share any history
with the primary development branches.  Perhaps they think it is cool
to do so, but it is not.  These independent branches originate from
different repositories, and are published in the same repository only
for easier distribution.  There is no reason for you (nor me) to
create such unrelated branches in a single originating repository.

A recommended procedure to publish independent branches in a single
repository is to push into one from separate, independent
repositories.  Starting an independent history in an existing
repository, like the main body of this message shows you how, is not
recommended.



-
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

[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]

  Powered by Linux