Skip to content

Commit cc6a9af

Browse files
pks-tgitster
authored andcommitted
reftable/iter: handle allocation failures when creating indexed table iter
Handle allocation failures in `new_indexed_table_ref_iter()`. While at it, rename the function to match our coding style. Signed-off-by: Patrick Steinhardt <[email protected]> Signed-off-by: Junio C Hamano <[email protected]>
1 parent 5b67cc6 commit cc6a9af

File tree

3 files changed

+23
-6
lines changed

3 files changed

+23
-6
lines changed

reftable/iter.c

Lines changed: 16 additions & 4 deletions
Original file line numberDiff line numberDiff line change
@@ -181,14 +181,20 @@ static int indexed_table_ref_iter_next(void *p, struct reftable_record *rec)
181181
}
182182
}
183183

184-
int new_indexed_table_ref_iter(struct indexed_table_ref_iter **dest,
184+
int indexed_table_ref_iter_new(struct indexed_table_ref_iter **dest,
185185
struct reftable_reader *r, uint8_t *oid,
186186
int oid_len, uint64_t *offsets, int offset_len)
187187
{
188188
struct indexed_table_ref_iter empty = INDEXED_TABLE_REF_ITER_INIT;
189-
struct indexed_table_ref_iter *itr = reftable_calloc(1, sizeof(*itr));
189+
struct indexed_table_ref_iter *itr;
190190
int err = 0;
191191

192+
itr = reftable_calloc(1, sizeof(*itr));
193+
if (!itr) {
194+
err = REFTABLE_OUT_OF_MEMORY_ERROR;
195+
goto out;
196+
}
197+
192198
*itr = empty;
193199
itr->r = r;
194200
strbuf_add(&itr->oid, oid, oid_len);
@@ -197,10 +203,16 @@ int new_indexed_table_ref_iter(struct indexed_table_ref_iter **dest,
197203
itr->offset_len = offset_len;
198204

199205
err = indexed_table_ref_iter_next_block(itr);
206+
if (err < 0)
207+
goto out;
208+
209+
*dest = itr;
210+
err = 0;
211+
212+
out:
200213
if (err < 0) {
214+
*dest = NULL;
201215
reftable_free(itr);
202-
} else {
203-
*dest = itr;
204216
}
205217
return err;
206218
}

reftable/iter.h

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -82,7 +82,7 @@ void iterator_from_indexed_table_ref_iter(struct reftable_iterator *it,
8282
struct indexed_table_ref_iter *itr);
8383

8484
/* Takes ownership of `offsets` */
85-
int new_indexed_table_ref_iter(struct indexed_table_ref_iter **dest,
85+
int indexed_table_ref_iter_new(struct indexed_table_ref_iter **dest,
8686
struct reftable_reader *r, uint8_t *oid,
8787
int oid_len, uint64_t *offsets, int offset_len);
8888

reftable/reader.c

Lines changed: 6 additions & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -715,7 +715,7 @@ static int reftable_reader_refs_for_indexed(struct reftable_reader *r,
715715
goto done;
716716
}
717717

718-
err = new_indexed_table_ref_iter(&itr, r, oid, hash_size(r->hash_id),
718+
err = indexed_table_ref_iter_new(&itr, r, oid, hash_size(r->hash_id),
719719
got.u.obj.offsets,
720720
got.u.obj.offset_len);
721721
if (err < 0)
@@ -740,6 +740,11 @@ static int reftable_reader_refs_for_unindexed(struct reftable_reader *r,
740740
int err;
741741

742742
REFTABLE_ALLOC_ARRAY(ti, 1);
743+
if (!ti) {
744+
err = REFTABLE_OUT_OF_MEMORY_ERROR;
745+
goto out;
746+
}
747+
743748
table_iter_init(ti, r);
744749
err = table_iter_seek_start(ti, BLOCK_TYPE_REF, 0);
745750
if (err < 0)

0 commit comments

Comments
 (0)