diff options
author | Junio C Hamano <gitster@pobox.com> | 2013-09-17 11:41:34 -0700 |
---|---|---|
committer | Junio C Hamano <gitster@pobox.com> | 2013-09-17 11:41:35 -0700 |
commit | 5ff9f2351a4d4dc31b0b11258d587c95826acc57 (patch) | |
tree | 2d8602481448fe260daa2189a238862c8b39fcec | |
parent | 541dc4dfa07f70e66e244be566480ed4699b4fc9 (diff) | |
parent | 45e8a7487339c0f0ea28244ef06851308d07387c (diff) | |
download | git-5ff9f2351a4d4dc31b0b11258d587c95826acc57.tar.gz |
Merge branch 'jk/has-sha1-file-retry-packed'
When an object is not found after checking the packfiles and then
loose object directory, read_sha1_file() re-checks the packfiles to
prevent racing with a concurrent repacker; teach the same logic to
has_sha1_file().
* jk/has-sha1-file-retry-packed:
has_sha1_file: re-check pack directory before giving up
-rw-r--r-- | sha1_file.c | 5 |
1 files changed, 4 insertions, 1 deletions
diff --git a/sha1_file.c b/sha1_file.c index 8c2d1ed52d..f1b649742f 100644 --- a/sha1_file.c +++ b/sha1_file.c @@ -2995,7 +2995,10 @@ int has_sha1_file(const unsigned char *sha1) if (find_pack_entry(sha1, &e)) return 1; - return has_loose_object(sha1); + if (has_loose_object(sha1)) + return 1; + reprepare_packed_git(); + return find_pack_entry(sha1, &e); } static void check_tree(const void *buf, size_t size) |