]> git.ipfire.org Git - thirdparty/git.git/commitdiff
bulk-checkin.c: store checksum directly
authorTaylor Blau <me@ttaylorr.com>
Thu, 9 Sep 2021 23:24:32 +0000 (19:24 -0400)
committerJunio C Hamano <gitster@pobox.com>
Fri, 10 Sep 2021 01:23:11 +0000 (18:23 -0700)
finish_bulk_checkin() stores the checksum from finalize_hashfile() by
writing to the `hash` member of `struct object_id`, but that hash has
nothing to do with an object id (it's just a convenient location that
happens to be sized correctly).

Store the hash directly in an unsigned char array. This behaves the same
as writing to the `hash` member, but makes the intent clearer (and
avoids allocating an extra four bytes for the `algo` member of `struct
object_id`). It likewise prevents the possibility of a segfault when
reading `algo` (e.g., by calling `oid_to_hex()`) if it is uninitialized.

Signed-off-by: Taylor Blau <me@ttaylorr.com>
Signed-off-by: Junio C Hamano <gitster@pobox.com>
bulk-checkin.c

index b023d9959aae4360cd42414a7f33ee11c550c61a..6283bc8bd967d444424ddc63c5b61f6139d3b0dc 100644 (file)
@@ -25,7 +25,7 @@ static struct bulk_checkin_state {
 
 static void finish_bulk_checkin(struct bulk_checkin_state *state)
 {
-       struct object_id oid;
+       unsigned char hash[GIT_MAX_RAWSZ];
        struct strbuf packname = STRBUF_INIT;
        int i;
 
@@ -37,11 +37,11 @@ static void finish_bulk_checkin(struct bulk_checkin_state *state)
                unlink(state->pack_tmp_name);
                goto clear_exit;
        } else if (state->nr_written == 1) {
-               finalize_hashfile(state->f, oid.hash, CSUM_HASH_IN_STREAM | CSUM_FSYNC | CSUM_CLOSE);
+               finalize_hashfile(state->f, hash, CSUM_HASH_IN_STREAM | CSUM_FSYNC | CSUM_CLOSE);
        } else {
-               int fd = finalize_hashfile(state->f, oid.hash, 0);
-               fixup_pack_header_footer(fd, oid.hash, state->pack_tmp_name,
-                                        state->nr_written, oid.hash,
+               int fd = finalize_hashfile(state->f, hash, 0);
+               fixup_pack_header_footer(fd, hash, state->pack_tmp_name,
+                                        state->nr_written, hash,
                                         state->offset);
                close(fd);
        }
@@ -49,7 +49,7 @@ static void finish_bulk_checkin(struct bulk_checkin_state *state)
        strbuf_addf(&packname, "%s/pack/pack-", get_object_directory());
        finish_tmp_packfile(&packname, state->pack_tmp_name,
                            state->written, state->nr_written,
-                           &state->pack_idx_opts, oid.hash);
+                           &state->pack_idx_opts, hash);
        for (i = 0; i < state->nr_written; i++)
                free(state->written[i]);