There are places in the code where we would like to provide a struct object_id *, yet read the hash directly from the pack. Provide an nth_packed_object_oid function that mirrors the nth_packed_object_sha1 function. The required cast is questionable, but should be safe on all known platforms. The alternative of allocating an object as an intermediate would be too inefficient and cause memory leaks. If necessary, an intermediate union could be used; this practice is allowed by GCC and explicitly sanctioned by C11. However, such a change will likely not be necessary, and can be made if and when it is. Signed-off-by: brian m. carlson <sandals@xxxxxxxxxxxxxxxxxxxx> --- cache.h | 1 + sha1_file.c | 12 +++++++++--- 2 files changed, 10 insertions(+), 3 deletions(-) diff --git a/cache.h b/cache.h index a50a61a19..b1ed1c7ae 100644 --- a/cache.h +++ b/cache.h @@ -1540,6 +1540,7 @@ extern void check_pack_index_ptr(const struct packed_git *p, const void *ptr); * error. */ extern const unsigned char *nth_packed_object_sha1(struct packed_git *, uint32_t n); +extern const struct object_id *nth_packed_object_oid(struct packed_git *, uint32_t n); /* * Return the offset of the nth object within the specified packfile. diff --git a/sha1_file.c b/sha1_file.c index 117307185..d27d1521b 100644 --- a/sha1_file.c +++ b/sha1_file.c @@ -2608,6 +2608,12 @@ const unsigned char *nth_packed_object_sha1(struct packed_git *p, } } +const struct object_id *nth_packed_object_oid(struct packed_git *p, + uint32_t n) +{ + return (const struct object_id *)nth_packed_object_sha1(p, n); +} + void check_pack_index_ptr(const struct packed_git *p, const void *vptr) { const unsigned char *ptr = vptr; @@ -3768,13 +3774,13 @@ static int for_each_object_in_pack(struct packed_git *p, each_packed_object_fn c int r = 0; for (i = 0; i < p->num_objects; i++) { - const unsigned char *sha1 = nth_packed_object_sha1(p, i); + const struct object_id *oid = nth_packed_object_oid(p, i); - if (!sha1) + if (!oid) return error("unable to get sha1 of object %u in %s", i, p->pack_name); - r = cb(sha1, p, i, data); + r = cb(oid->hash, p, i, data); if (r) break; } -- 2.11.0