Merge branch 'bc/object-id'
Conversion from unsigned char [40] to struct object_id continues. * bc/object-id: Documentation: update and rename api-sha1-array.txt Rename sha1_array to oid_array Convert sha1_array_for_each_unique and for_each_abbrev to object_id Convert sha1_array_lookup to take struct object_id Convert remaining callers of sha1_array_lookup to object_id Make sha1_array_append take a struct object_id * sha1-array: convert internal storage for struct sha1_array to object_id builtin/pull: convert to struct object_id submodule: convert check_for_new_submodule_commits to object_id sha1_name: convert disambiguate_hint_fn to take object_id sha1_name: convert struct disambiguate_state to object_id test-sha1-array: convert most code to struct object_id parse-options-cb: convert sha1_array_append caller to struct object_id fsck: convert init_skiplist to struct object_id builtin/receive-pack: convert portions to struct object_id builtin/pull: convert portions to struct object_id builtin/diff: convert to struct object_id Convert GIT_SHA1_RAWSZ used for allocation to GIT_MAX_RAWSZ Convert GIT_SHA1_HEXSZ used for allocation to GIT_MAX_HEXSZ Define new hash-size constants for allocating memory
This commit is contained in:
@ -2672,16 +2672,16 @@ static int has_sha1_pack_kept_or_nonlocal(const unsigned char *sha1)
|
||||
*
|
||||
* This is filled by get_object_list.
|
||||
*/
|
||||
static struct sha1_array recent_objects;
|
||||
static struct oid_array recent_objects;
|
||||
|
||||
static int loosened_object_can_be_discarded(const unsigned char *sha1,
|
||||
static int loosened_object_can_be_discarded(const struct object_id *oid,
|
||||
unsigned long mtime)
|
||||
{
|
||||
if (!unpack_unreachable_expiration)
|
||||
return 0;
|
||||
if (mtime > unpack_unreachable_expiration)
|
||||
return 0;
|
||||
if (sha1_array_lookup(&recent_objects, sha1) >= 0)
|
||||
if (oid_array_lookup(&recent_objects, oid) >= 0)
|
||||
return 0;
|
||||
return 1;
|
||||
}
|
||||
@ -2690,7 +2690,7 @@ static void loosen_unused_packed_objects(struct rev_info *revs)
|
||||
{
|
||||
struct packed_git *p;
|
||||
uint32_t i;
|
||||
const unsigned char *sha1;
|
||||
struct object_id oid;
|
||||
|
||||
for (p = packed_git; p; p = p->next) {
|
||||
if (!p->pack_local || p->pack_keep)
|
||||
@ -2700,11 +2700,11 @@ static void loosen_unused_packed_objects(struct rev_info *revs)
|
||||
die("cannot open pack index");
|
||||
|
||||
for (i = 0; i < p->num_objects; i++) {
|
||||
sha1 = nth_packed_object_sha1(p, i);
|
||||
if (!packlist_find(&to_pack, sha1, NULL) &&
|
||||
!has_sha1_pack_kept_or_nonlocal(sha1) &&
|
||||
!loosened_object_can_be_discarded(sha1, p->mtime))
|
||||
if (force_object_loose(sha1, p->mtime))
|
||||
nth_packed_object_oid(&oid, p, i);
|
||||
if (!packlist_find(&to_pack, oid.hash, NULL) &&
|
||||
!has_sha1_pack_kept_or_nonlocal(oid.hash) &&
|
||||
!loosened_object_can_be_discarded(&oid, p->mtime))
|
||||
if (force_object_loose(oid.hash, p->mtime))
|
||||
die("unable to force loose object");
|
||||
}
|
||||
}
|
||||
@ -2743,12 +2743,12 @@ static void record_recent_object(struct object *obj,
|
||||
const char *name,
|
||||
void *data)
|
||||
{
|
||||
sha1_array_append(&recent_objects, obj->oid.hash);
|
||||
oid_array_append(&recent_objects, &obj->oid);
|
||||
}
|
||||
|
||||
static void record_recent_commit(struct commit *commit, void *data)
|
||||
{
|
||||
sha1_array_append(&recent_objects, commit->object.oid.hash);
|
||||
oid_array_append(&recent_objects, &commit->object.oid);
|
||||
}
|
||||
|
||||
static void get_object_list(int ac, const char **av)
|
||||
@ -2816,7 +2816,7 @@ static void get_object_list(int ac, const char **av)
|
||||
if (unpack_unreachable)
|
||||
loosen_unused_packed_objects(&revs);
|
||||
|
||||
sha1_array_clear(&recent_objects);
|
||||
oid_array_clear(&recent_objects);
|
||||
}
|
||||
|
||||
static int option_parse_index_version(const struct option *opt,
|
||||
|
Reference in New Issue
Block a user