diff options
author | Junio C Hamano <gitster@pobox.com> | 2019-04-25 10:41:19 +0300 |
---|---|---|
committer | Junio C Hamano <gitster@pobox.com> | 2019-04-25 10:41:19 +0300 |
commit | 32dc15dec1cd9e9fada2983094484ae6e4c93647 (patch) | |
tree | 625393be9fb971cf5c803d2ba3997a4741e4cbc7 /object-store.h | |
parent | ac70c5313351630e44b1fe0267fb4850ebcf1f25 (diff) | |
parent | 7fbbcb21b162883615d5542e06fb2eb8685fd496 (diff) |
Merge branch 'jt/batch-fetch-blobs-in-diff'
While running "git diff" in a lazy clone, we can upfront know which
missing blobs we will need, instead of waiting for the on-demand
machinery to discover them one by one. Aim to achieve better
performance by batching the request for these promised blobs.
* jt/batch-fetch-blobs-in-diff:
diff: batch fetching of missing blobs
sha1-file: support OBJECT_INFO_FOR_PREFETCH
Diffstat (limited to 'object-store.h')
-rw-r--r-- | object-store.h | 6 |
1 files changed, 6 insertions, 0 deletions
diff --git a/object-store.h b/object-store.h index 56f8aea1cc..b086f5ecdb 100644 --- a/object-store.h +++ b/object-store.h @@ -280,6 +280,12 @@ struct object_info { #define OBJECT_INFO_QUICK 8 /* Do not check loose object */ #define OBJECT_INFO_IGNORE_LOOSE 16 +/* + * Do not attempt to fetch the object if missing (even if fetch_is_missing is + * nonzero). This is meant for bulk prefetching of missing blobs in a partial + * clone. Implies OBJECT_INFO_QUICK. + */ +#define OBJECT_INFO_FOR_PREFETCH (32 + OBJECT_INFO_QUICK) int oid_object_info_extended(struct repository *r, const struct object_id *, |