diff options
author | Kimplul <kimi.h.kuparinen@gmail.com> | 2025-01-05 23:27:48 +0200 |
---|---|---|
committer | Kimplul <kimi.h.kuparinen@gmail.com> | 2025-01-05 23:27:48 +0200 |
commit | b5048ca2997d373c7e9b8938d29c542b891ce970 (patch) | |
tree | 522d741636ebf206b06d0e38c09042eb6d96bcaf | |
parent | 1f57645d9550e486a5bc209a0652bfad7fb8872a (diff) | |
download | conts-b5048ca2997d373c7e9b8938d29c542b891ce970.tar.gz conts-b5048ca2997d373c7e9b8938d29c542b891ce970.zip |
remember to free nodes in sptree
-rw-r--r-- | include/conts/sptree.h | 10 | ||||
-rw-r--r-- | tests/htrie.c | 22 |
2 files changed, 8 insertions, 24 deletions
diff --git a/include/conts/sptree.h b/include/conts/sptree.h index 75b88fc..e305c0f 100644 --- a/include/conts/sptree.h +++ b/include/conts/sptree.h @@ -400,12 +400,18 @@ static inline void SPTREE(remove)(struct SPROOT *s, SPTREE_TYPE data) return; SPTREE(remove_found)(s, found); + struct SPNODE *del = CONTAINER_OF(found, struct SPNODE, data); + free(del); } static inline void SPTREE(destroy)(struct SPROOT *s) { - while (s->root) - SPTREE(remove_found)(s, &s->root->data); + while (s->root) { + SPTREE_TYPE *top = &s->root->data; + SPTREE(remove_found)(s, top); + struct SPNODE *del = CONTAINER_OF(top, struct SPNODE, data); + free(del); + } } #undef SPTREE diff --git a/tests/htrie.c b/tests/htrie.c deleted file mode 100644 index 2c70b38..0000000 --- a/tests/htrie.c +++ /dev/null @@ -1,22 +0,0 @@ -#include <assert.h> - -#define HTRIE_TYPE int -#define HTRIE_KEY int -#define HTRIE_HASH conts_inthash -#define HTRIE_CMP(a, b) ((a) - (b)) -#define HTRIE_NAME ints -#include <conts/htrie.h> - -int main() -{ - struct ints ints = ints_create(); - for (int i = 0; i < 1000000; ++i) { - ints_insert(&ints, i, i); - } - - for (int i = 0; i < 1000000; ++i) { - int *v = ints_at(&ints, i); - assert(v && *v == i); - } - ints_destroy(&ints); -} |