aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorSteven Grimm <koreth@midwinter.com>2008-08-05 13:08:41 -0700
committerJunio C Hamano <gitster@pobox.com>2008-08-05 21:21:20 -0700
commitddd63e64e4ac7e455dff3e807bf6a6977bb61456 (patch)
tree7aa1f68152ab489b540f9d4c742303c387c05e38
parent3d32a46b247222a97007419fa865efce959b002d (diff)
downloadgit-ddd63e64e4ac7e455dff3e807bf6a6977bb61456.tar.gz
git-ddd63e64e4ac7e455dff3e807bf6a6977bb61456.tar.xz
Optimize sha1_object_info for loose objects, not concurrent repacks
When dealing with a repository with lots of loose objects, sha1_object_info would rescan the packs directory every time an unpacked object was referenced before finally giving up and looking for the loose object. This caused a lot of extra unnecessary system calls during git pack-objects; the code was rereading the entire pack directory once for each loose object file. This patch looks for a loose object before falling back to rescanning the pack directory, rather than the other way around. Signed-off-by: Steven Grimm <koreth@midwinter.com> Acked-by: Shawn O. Pearce <spearce@spearce.org> Signed-off-by: Junio C Hamano <gitster@pobox.com>
-rw-r--r--sha1_file.c9
1 files changed, 8 insertions, 1 deletions
diff --git a/sha1_file.c b/sha1_file.c
index e281c14f0..32e4664b1 100644
--- a/sha1_file.c
+++ b/sha1_file.c
@@ -1929,11 +1929,18 @@ static int sha1_loose_object_info(const unsigned char *sha1, unsigned long *size
int sha1_object_info(const unsigned char *sha1, unsigned long *sizep)
{
struct pack_entry e;
+ int status;
if (!find_pack_entry(sha1, &e, NULL)) {
+ /* Most likely it's a loose object. */
+ status = sha1_loose_object_info(sha1, sizep);
+ if (status >= 0)
+ return status;
+
+ /* Not a loose object; someone else may have just packed it. */
reprepare_packed_git();
if (!find_pack_entry(sha1, &e, NULL))
- return sha1_loose_object_info(sha1, sizep);
+ return status;
}
return packed_object_info(e.p, e.offset, sizep);
}