From e423b41e74e24ec6d4bf971715dc819d3da5fa42 Mon Sep 17 00:00:00 2001 From: Andreas Molzer Date: Tue, 24 Mar 2020 15:30:20 +0100 Subject: [PATCH 1/3] Fix arraddn returning index instead of pointer The documentation of that operation already said: > Returns a pointer to the first uninitialized item added. This also makes a lot of sense, allowing easy initialization. But the implementation returned the index of the first uninitialized element instead. --- stb_ds.h | 3 ++- 1 file changed, 2 insertions(+), 1 deletion(-) diff --git a/stb_ds.h b/stb_ds.h index 4c1b221..cddb2c2 100644 --- a/stb_ds.h +++ b/stb_ds.h @@ -370,6 +370,7 @@ CREDITS Andy Durdin Shane Liesegang Vinh Truong + Andreas Molzer */ #ifdef STBDS_UNIT_TESTS @@ -521,7 +522,7 @@ extern void * stbds_shmode_func(size_t elemsize, int mode); #define stbds_arrput(a,v) (stbds_arrmaybegrow(a,1), (a)[stbds_header(a)->length++] = (v)) #define stbds_arrpush stbds_arrput // synonym #define stbds_arrpop(a) (stbds_header(a)->length--, (a)[stbds_header(a)->length]) -#define stbds_arraddn(a,n) (stbds_arrmaybegrow(a,n), stbds_header(a)->length += (n), stbds_header(a)->length-(n)) +#define stbds_arraddn(a,n) (stbds_arrmaybegrow(a,n), stbds_header(a)->length += (n), &(a)[stbds_header(a)->length-(n)]) #define stbds_arrlast(a) ((a)[stbds_header(a)->length-1]) #define stbds_arrfree(a) ((void) ((a) ? STBDS_FREE(NULL,stbds_header(a)) : (void)0), (a)=NULL) #define stbds_arrdel(a,i) stbds_arrdeln(a,i,1) From e485c7d35380d995a4943639b0d103ee8db68a20 Mon Sep 17 00:00:00 2001 From: Andreas Molzer Date: Wed, 25 Mar 2020 20:12:21 +0100 Subject: [PATCH 2/3] Split arraddn into pointer and index return --- stb_ds.h | 15 +++++++++++---- 1 file changed, 11 insertions(+), 4 deletions(-) diff --git a/stb_ds.h b/stb_ds.h index cddb2c2..09f37f8 100644 --- a/stb_ds.h +++ b/stb_ds.h @@ -108,11 +108,16 @@ DOCUMENTATION Inserts n uninitialized items into array a starting at a[p], moving the rest of the array over. - arraddn: - T* arraddn(T* a, int n) + arraddnptr: + T* arraddnptr(T* a, int n) Appends n uninitialized items onto array at the end. Returns a pointer to the first uninitialized item added. + arraddnoff: + size_t arraddnoff(T* a, int n) + Appends n uninitialized items onto array at the end. + Returns the index of the first uninitialized item added. + arrdel: void arrdel(T* a, int p); Deletes the element at a[p], moving the rest of the array over. @@ -390,7 +395,8 @@ CREDITS #define arrpush stbds_arrput #define arrpop stbds_arrpop #define arrfree stbds_arrfree -#define arraddn stbds_arraddn +#define arraddnptr stbds_arraddnptr +#define arraddnoff stbds_arraddnoff #define arrsetlen stbds_arrsetlen #define arrlast stbds_arrlast #define arrins stbds_arrins @@ -522,7 +528,8 @@ extern void * stbds_shmode_func(size_t elemsize, int mode); #define stbds_arrput(a,v) (stbds_arrmaybegrow(a,1), (a)[stbds_header(a)->length++] = (v)) #define stbds_arrpush stbds_arrput // synonym #define stbds_arrpop(a) (stbds_header(a)->length--, (a)[stbds_header(a)->length]) -#define stbds_arraddn(a,n) (stbds_arrmaybegrow(a,n), stbds_header(a)->length += (n), &(a)[stbds_header(a)->length-(n)]) +#define stbds_arraddnptr(a,n) (stbds_arrmaybegrow(a,n), stbds_header(a)->length += (n), &(a)[stbds_header(a)->length-(n)]) +#define stbds_arraddnoff(a,n) (stbds_arrmaybegrow(a,n), stbds_header(a)->length += (n), stbds_header(a)->length-(n)) #define stbds_arrlast(a) ((a)[stbds_header(a)->length-1]) #define stbds_arrfree(a) ((void) ((a) ? STBDS_FREE(NULL,stbds_header(a)) : (void)0), (a)=NULL) #define stbds_arrdel(a,i) stbds_arrdeln(a,i,1) From b67dabed2a7f1390e55dde473ef9bf20911431be Mon Sep 17 00:00:00 2001 From: Andreas Molzer Date: Wed, 25 Mar 2020 20:58:01 +0100 Subject: [PATCH 3/3] Add arraddn back with void return and deprecated --- stb_ds.h | 4 ++++ 1 file changed, 4 insertions(+) diff --git a/stb_ds.h b/stb_ds.h index 09f37f8..e0bff97 100644 --- a/stb_ds.h +++ b/stb_ds.h @@ -397,6 +397,8 @@ CREDITS #define arrfree stbds_arrfree #define arraddnptr stbds_arraddnptr #define arraddnoff stbds_arraddnoff +// deprecated +#define arraddn stbds_arraddn #define arrsetlen stbds_arrsetlen #define arrlast stbds_arrlast #define arrins stbds_arrins @@ -528,6 +530,8 @@ extern void * stbds_shmode_func(size_t elemsize, int mode); #define stbds_arrput(a,v) (stbds_arrmaybegrow(a,1), (a)[stbds_header(a)->length++] = (v)) #define stbds_arrpush stbds_arrput // synonym #define stbds_arrpop(a) (stbds_header(a)->length--, (a)[stbds_header(a)->length]) +// deprecated +#define stbds_arraddn(a,n) ((void)(stbds_arraddnoff(a, n))) #define stbds_arraddnptr(a,n) (stbds_arrmaybegrow(a,n), stbds_header(a)->length += (n), &(a)[stbds_header(a)->length-(n)]) #define stbds_arraddnoff(a,n) (stbds_arrmaybegrow(a,n), stbds_header(a)->length += (n), stbds_header(a)->length-(n)) #define stbds_arrlast(a) ((a)[stbds_header(a)->length-1])