reftable: introduce macros to allocate arrays
Similar to the preceding commit, let's carry over macros to allocate arrays with `REFTABLE_ALLOC_ARRAY()` and `REFTABLE_CALLOC_ARRAY()`. This requires us to change the signature of `reftable_calloc()`, which only takes a single argument right now and thus puts the burden on the caller to calculate the final array's size. This is a net improvement though as it means that we can now provide proper overflow checks when multiplying the array size with the member size. Convert callsites of `reftable_calloc()` to the new signature and start using the new macros where possible. Signed-off-by: Patrick Steinhardt <ps@pks.im> Signed-off-by: Junio C Hamano <gitster@pobox.com>
This commit is contained in:

committed by
Junio C Hamano

parent
f6b58c1be4
commit
b4ff12c8ee
@ -497,12 +497,13 @@ static void reftable_obj_record_copy_from(void *rec, const void *src_rec,
|
||||
(const struct reftable_obj_record *)src_rec;
|
||||
|
||||
reftable_obj_record_release(obj);
|
||||
obj->hash_prefix = reftable_malloc(src->hash_prefix_len);
|
||||
|
||||
REFTABLE_ALLOC_ARRAY(obj->hash_prefix, src->hash_prefix_len);
|
||||
obj->hash_prefix_len = src->hash_prefix_len;
|
||||
if (src->hash_prefix_len)
|
||||
memcpy(obj->hash_prefix, src->hash_prefix, obj->hash_prefix_len);
|
||||
|
||||
obj->offsets = reftable_malloc(src->offset_len * sizeof(uint64_t));
|
||||
REFTABLE_ALLOC_ARRAY(obj->offsets, src->offset_len);
|
||||
obj->offset_len = src->offset_len;
|
||||
COPY_ARRAY(obj->offsets, src->offsets, src->offset_len);
|
||||
}
|
||||
@ -559,7 +560,8 @@ static int reftable_obj_record_decode(void *rec, struct strbuf key,
|
||||
int n = 0;
|
||||
uint64_t last;
|
||||
int j;
|
||||
r->hash_prefix = reftable_malloc(key.len);
|
||||
|
||||
REFTABLE_ALLOC_ARRAY(r->hash_prefix, key.len);
|
||||
memcpy(r->hash_prefix, key.buf, key.len);
|
||||
r->hash_prefix_len = key.len;
|
||||
|
||||
@ -577,7 +579,7 @@ static int reftable_obj_record_decode(void *rec, struct strbuf key,
|
||||
if (count == 0)
|
||||
return start.len - in.len;
|
||||
|
||||
r->offsets = reftable_malloc(count * sizeof(uint64_t));
|
||||
REFTABLE_ALLOC_ARRAY(r->offsets, count);
|
||||
r->offset_len = count;
|
||||
|
||||
n = get_var_int(&r->offsets[0], &in);
|
||||
@ -715,12 +717,12 @@ static void reftable_log_record_copy_from(void *rec, const void *src_rec,
|
||||
}
|
||||
|
||||
if (dst->value.update.new_hash) {
|
||||
dst->value.update.new_hash = reftable_malloc(hash_size);
|
||||
REFTABLE_ALLOC_ARRAY(dst->value.update.new_hash, hash_size);
|
||||
memcpy(dst->value.update.new_hash,
|
||||
src->value.update.new_hash, hash_size);
|
||||
}
|
||||
if (dst->value.update.old_hash) {
|
||||
dst->value.update.old_hash = reftable_malloc(hash_size);
|
||||
REFTABLE_ALLOC_ARRAY(dst->value.update.old_hash, hash_size);
|
||||
memcpy(dst->value.update.old_hash,
|
||||
src->value.update.old_hash, hash_size);
|
||||
}
|
||||
|
Reference in New Issue
Block a user