Mercurial > libedl
changeset 6:7137fbac0b85
edl: expose EDL_reallocate() API to allow resizing the array
author | Paper <mrpapersonic@gmail.com> |
---|---|
date | Thu, 28 Dec 2023 16:47:24 -0500 (13 months ago) |
parents | a6ab6d9c0dac |
children | fee08fa622e1 |
files | include/edl.h src/edl.c |
diffstat | 2 files changed, 5 insertions(+), 4 deletions(-) [+] |
line wrap: on
line diff
--- a/include/edl.h Mon Dec 25 16:26:46 2023 -0500 +++ b/include/edl.h Thu Dec 28 16:47:24 2023 -0500 @@ -54,6 +54,7 @@ } EDL; EDL EDL_parse(const char* text, size_t length); +int EDL_reallocate(EDL* edl, size_t new_capacity); char* EDL_dump(EDL edl); void EDL_free(EDL edl);
--- a/src/edl.c Mon Dec 25 16:26:46 2023 -0500 +++ b/src/edl.c Thu Dec 28 16:47:24 2023 -0500 @@ -144,7 +144,7 @@ /* memory management routines */ -static int EDL_internal_reallocate(EDL* input, size_t new_capacity) { +int EDL_reallocate(EDL* input, size_t new_capacity) { input->arr = realloc(input->arr, new_capacity * sizeof(EDL_line)); if (!input->arr) return 0; @@ -160,7 +160,7 @@ /* the important function */ EDL EDL_parse(const char* data, size_t length) { EDL edl = {0}; - if (!EDL_internal_reallocate(&edl, 16)) + if (!EDL_reallocate(&edl, 16)) return edl; size_t order_size = 0; @@ -282,10 +282,10 @@ break; if (++edl.size >= edl.capacity) - EDL_internal_reallocate(&edl, edl.capacity * 2); + EDL_reallocate(&edl, edl.capacity * 2); } - EDL_internal_reallocate(&edl, edl.size); + EDL_reallocate(&edl, edl.size); free(order);