Merge branch 'jt/sha1-file-remove-oi-skip-cached' into maint
has_object_file() said "no" given an object registered to the system via pretend_object_file(), making it inconsistent with read_object_file(), causing lazy fetch to attempt fetching an empty tree from promisor remotes. * jt/sha1-file-remove-oi-skip-cached: sha1-file: remove OBJECT_INFO_SKIP_CACHEDmaint
commit
9eddeaece1
|
@ -292,8 +292,6 @@ struct object_info {
|
||||||
#define OBJECT_INFO_LOOKUP_REPLACE 1
|
#define OBJECT_INFO_LOOKUP_REPLACE 1
|
||||||
/* Allow reading from a loose object file of unknown/bogus type */
|
/* Allow reading from a loose object file of unknown/bogus type */
|
||||||
#define OBJECT_INFO_ALLOW_UNKNOWN_TYPE 2
|
#define OBJECT_INFO_ALLOW_UNKNOWN_TYPE 2
|
||||||
/* Do not check cached storage */
|
|
||||||
#define OBJECT_INFO_SKIP_CACHED 4
|
|
||||||
/* Do not retry packed storage after checking packed and loose storage */
|
/* Do not retry packed storage after checking packed and loose storage */
|
||||||
#define OBJECT_INFO_QUICK 8
|
#define OBJECT_INFO_QUICK 8
|
||||||
/* Do not check loose object */
|
/* Do not check loose object */
|
||||||
|
|
38
sha1-file.c
38
sha1-file.c
|
@ -1417,6 +1417,7 @@ int oid_object_info_extended(struct repository *r, const struct object_id *oid,
|
||||||
struct object_info *oi, unsigned flags)
|
struct object_info *oi, unsigned flags)
|
||||||
{
|
{
|
||||||
static struct object_info blank_oi = OBJECT_INFO_INIT;
|
static struct object_info blank_oi = OBJECT_INFO_INIT;
|
||||||
|
struct cached_object *co;
|
||||||
struct pack_entry e;
|
struct pack_entry e;
|
||||||
int rtype;
|
int rtype;
|
||||||
const struct object_id *real = oid;
|
const struct object_id *real = oid;
|
||||||
|
@ -1431,24 +1432,22 @@ int oid_object_info_extended(struct repository *r, const struct object_id *oid,
|
||||||
if (!oi)
|
if (!oi)
|
||||||
oi = &blank_oi;
|
oi = &blank_oi;
|
||||||
|
|
||||||
if (!(flags & OBJECT_INFO_SKIP_CACHED)) {
|
co = find_cached_object(real);
|
||||||
struct cached_object *co = find_cached_object(real);
|
if (co) {
|
||||||
if (co) {
|
if (oi->typep)
|
||||||
if (oi->typep)
|
*(oi->typep) = co->type;
|
||||||
*(oi->typep) = co->type;
|
if (oi->sizep)
|
||||||
if (oi->sizep)
|
*(oi->sizep) = co->size;
|
||||||
*(oi->sizep) = co->size;
|
if (oi->disk_sizep)
|
||||||
if (oi->disk_sizep)
|
*(oi->disk_sizep) = 0;
|
||||||
*(oi->disk_sizep) = 0;
|
if (oi->delta_base_sha1)
|
||||||
if (oi->delta_base_sha1)
|
hashclr(oi->delta_base_sha1);
|
||||||
hashclr(oi->delta_base_sha1);
|
if (oi->type_name)
|
||||||
if (oi->type_name)
|
strbuf_addstr(oi->type_name, type_name(co->type));
|
||||||
strbuf_addstr(oi->type_name, type_name(co->type));
|
if (oi->contentp)
|
||||||
if (oi->contentp)
|
*oi->contentp = xmemdupz(co->buf, co->size);
|
||||||
*oi->contentp = xmemdupz(co->buf, co->size);
|
oi->whence = OI_CACHED;
|
||||||
oi->whence = OI_CACHED;
|
return 0;
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
while (1) {
|
while (1) {
|
||||||
|
@ -1932,8 +1931,7 @@ int repo_has_object_file_with_flags(struct repository *r,
|
||||||
{
|
{
|
||||||
if (!startup_info->have_repository)
|
if (!startup_info->have_repository)
|
||||||
return 0;
|
return 0;
|
||||||
return oid_object_info_extended(r, oid, NULL,
|
return oid_object_info_extended(r, oid, NULL, flags) >= 0;
|
||||||
flags | OBJECT_INFO_SKIP_CACHED) >= 0;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
int repo_has_object_file(struct repository *r,
|
int repo_has_object_file(struct repository *r,
|
||||||
|
|
Loading…
Reference in New Issue