Code

[PATCH] Make .git directory validation code test HEAD
authorLinus Torvalds <torvalds@osdl.org>
Sat, 27 Aug 2005 20:54:42 +0000 (13:54 -0700)
committerJunio C Hamano <junkio@cox.net>
Sun, 28 Aug 2005 06:20:24 +0000 (23:20 -0700)
commit5f5608bcec417d4c92ac727fdcc83563730c21e9
tree6582d615c7bbad333fc473c06293330a228d1caa
parent9740d289ee76097a2ec43e59f7ecb8974bcf8634
[PATCH] Make .git directory validation code test HEAD

Inspired by a report by Kalle Valo, this changes git-sh-setup-script and
the "setup_git_directory()" function to test that $GIT_DIR/HEAD is a
symlink, since a number of core git features depend on that these days.

We used to allow a regular file there, but git-fsck-cache has been
complaining about that for a while, and anything that uses branches
depends on the HEAD file being a symlink, so let's just encode that as a
fundamental requirement.

Before, a non-symlink HEAD file would appear to work, but have subtle bugs
like not having the HEAD show up as a valid reference (because it wasn't
under "refs"). Now, we will complain loudly, and the user can fix it up
trivially instead of getting strange behaviour.

This also removes the tests for "$GIT_DIR" and "$GIT_OBJECT_DIRECTORY"
being directories, since the other tests will implicitly test for that
anyway (ie the tests for HEAD, refs and 00 would fail).

Signed-off-by: Linus Torvalds <torvalds@osdl.org>
Signed-off-by: Junio C Hamano <junkio@cox.net>
git-sh-setup-script
setup.c