pack-refs: prune top-level refs like "refs/foo"
commitafd11d3ebcfb18c29840dfa68be32c5215810a77
authorJeff King <peff@peff.net>
Sat, 23 Aug 2014 05:27:07 +0000 (23 01:27 -0400)
committerJunio C Hamano <gitster@pobox.com>
Mon, 25 Aug 2014 19:19:50 +0000 (25 12:19 -0700)
tree1cc5fd232b72e6c8e10f0650788b290c37099710
parent32f56600bb6ac6fc57183e79d2c1515dfa56672f
pack-refs: prune top-level refs like "refs/foo"

After we have packed all refs, we prune any loose refs that
correspond to what we packed. We do so by first taking a
lock with lock_ref_sha1, and then deleting the loose ref
file.

However, lock_ref_sha1 will refuse to take a lock on any
refs that exist at the top-level of the "refs/" directory,
and we skip pruning the ref.  This is almost certainly not
what we want to happen here. The criteria to be pruned
should not differ from that to be packed; if a ref makes it
to prune_ref, it's because we want it both packed and
pruned (if there are refs you do not want to be packed, they
should be omitted much earlier by pack_ref_is_possible,
which we do in this case if --all is not given).

We can fix this by switching to lock_any_ref_for_update.
This behaves exactly the same with the exception of this
top-level check.

Signed-off-by: Jeff King <peff@peff.net>
Reviewed-by: Michael Haggerty <mhagger@alum.mit.edu>
Reviewed-by: Ronnie Sahlberg <sahlberg@google.com>
Signed-off-by: Junio C Hamano <gitster@pobox.com>
refs.c
t/t3210-pack-refs.sh