peel_ref: check object type before loading
authorJeff King <peff@peff.net>
Thu, 4 Oct 2012 08:02:53 +0000 (04:02 -0400)
committerJunio C Hamano <gitster@pobox.com>
Fri, 5 Oct 2012 03:34:28 +0000 (20:34 -0700)
commit6c4a060d7d895c90610eb442cb4f910fe43ef13a
tree8d7a9e6e23919cc3d5eeb477145298d352cd6583
parente6dbffa67b8e4c463a8fe18e8599b8623d7f0485
peel_ref: check object type before loading

The point of peel_ref is to dereference tags; if the base
object is not a tag, then we can return early without even
loading the object into memory.

This patch accomplishes that by checking sha1_object_info
for the type. For a packed object, we can get away with just
looking in the pack index. For a loose object, we only need
to inflate the first couple of header bytes.

This is a bit of a gamble; if we do find a tag object, then
we will end up loading the content anyway, and the extra
lookup will have been wasteful. However, if it is not a tag
object, then we save loading the object entirely. Depending
on the ratio of non-tags to tags in the input, this can be a
minor win or minor loss.

However, it does give us one potential major win: if a ref
points to a large blob (e.g., via an unannotated tag), then
we can avoid looking at it entirely.

Signed-off-by: Jeff King <peff@peff.net>
Signed-off-by: Junio C Hamano <gitster@pobox.com>
refs.c