libbitvec-c

C bit vector library
git clone https://git.sinitax.com/sinitax/libbitvec-c
Log | Files | Refs | LICENSE | sfeed.txt

commit 78cdbdf01dfca7700db07caec49067eb44b09721
parent 6431e7434c0b935c5825322d286d5721f1782d32
Author: Louis Burda <quent.burda@gmail.com>
Date:   Mon, 13 Mar 2023 12:59:36 +0100

Prevent memory leak when realloc fails

Diffstat:
Msrc/bitvec.c | 15+++++++++------
1 file changed, 9 insertions(+), 6 deletions(-)

diff --git a/src/bitvec.c b/src/bitvec.c @@ -73,17 +73,19 @@ bitvec_free(struct bitvec *vec) bool bitvec_reserve(struct bitvec *vec, size_t cnt) { + void *alloc; + LIBBITVEC_ASSERT(vec != NULL); cnt = BITCEIL(cnt); if (vec->cap >= cnt) return true; - vec->data = realloc(vec->data, SLOTCNT(cnt) * SLOT_BYTES); - if (!vec->data) { + alloc = realloc(vec->data, SLOTCNT(cnt) * SLOT_BYTES); + if (!alloc) { LIBBITVEC_HANDLE_ERR("realloc"); return false; } - + alloc = vec->data; memset(vec->data + SLOT(vec->cap), 0, SLOT(cnt) - SLOT(vec->cap)); vec->cap = cnt; @@ -93,17 +95,18 @@ bitvec_reserve(struct bitvec *vec, size_t cnt) bool bitvec_shrink(struct bitvec *vec, size_t cnt) { + void *alloc; LIBBITVEC_ASSERT(vec != NULL); cnt = BITCEIL(cnt); if (vec->cap <= cnt) return true; - vec->data = realloc(vec->data, SLOTCNT(cnt)); - if (!vec->data) { + alloc = realloc(vec->data, SLOTCNT(cnt)); + if (!alloc) { LIBBITVEC_HANDLE_ERR("realloc"); return false; } - + vec->data = alloc; vec->cap = cnt; return true;