checkout.c: use ref_exists instead of file_exist
commit482b8f3208e797f00db58edd7ff0d67275e898f5
authorRonnie Sahlberg <sahlberg@google.com>
Tue, 6 May 2014 22:45:53 +0000 (6 15:45 -0700)
committerJunio C Hamano <gitster@pobox.com>
Thu, 8 May 2014 21:31:44 +0000 (8 14:31 -0700)
tree5d06db528220f8e9e4fc64cdb243a2103fc3cf23
parent4da588357a4a8b73f6a8d9c24435dabee74d0a7e
checkout.c: use ref_exists instead of file_exist

Change checkout.c to check if a ref exists instead of checking if a loose ref
file exists when deciding if to delete an orphaned log file. Otherwise, if a
ref only exists as a packed ref without a corresponding loose ref for the
currently checked out branch, we risk that the reflog will be deleted when we
switch to a different branch.

Update the reflog tests to check for this bug.

The following reproduces the bug:
$ git init-db
$ git config core.logallrefupdates true
$ git commit -m Initial --allow-empty
    [master (root-commit) bb11abe] Initial
$ git reflog master
    [8561dcb master@{0}: commit (initial): Initial]
$ find .git/{refs,logs} -type f | grep master
    [.git/refs/heads/master]
    [.git/logs/refs/heads/master]
$ git branch foo
$ git pack-refs --all
$ find .git/{refs,logs} -type f | grep master
    [.git/logs/refs/heads/master]
$ git checkout foo
$ find .git/{refs,logs} -type f | grep master
    ... reflog file is missing ...
$ git reflog master
    ... nothing ...

Signed-off-by: Ronnie Sahlberg <sahlberg@google.com>
Acked-by: Michael Haggerty <mhagger@alum.mit.edu>
Signed-off-by: Junio C Hamano <gitster@pobox.com>
builtin/checkout.c
t/t1410-reflog.sh