diff options
Diffstat (limited to 'src/hashmap.c')
| -rw-r--r-- | src/hashmap.c | 47 | 
1 files changed, 24 insertions, 23 deletions
| diff --git a/src/hashmap.c b/src/hashmap.c index 2787435..6b51d3e 100644 --- a/src/hashmap.c +++ b/src/hashmap.c @@ -215,37 +215,38 @@ hashmap_remove(struct hashmap *hm, const char *key)      return NULL;  } +#define HASHMAP_WALK(hm, ...) \ +	struct node *node; \ +	struct node *next; \ +	for (size_t i = 0; i < hm->cur_cap; i++) { \ +		node = hm->buckets[i]; \ +		while (node) { \ +			next = node->next; \ +			__VA_ARGS__; \ +			node = next; \ +		} \ +	} +  void -hashmap_walk(struct hashmap *hm, void (*fn)(const void *key, void *value)) +hashmap_walk(struct hashmap *hm, hashmap_cb cb)  { -    struct node *node; -    struct node *next; +	HASHMAP_WALK(hm, cb(node->key, node->value)); +} -    for (int i=0; i < hm->cur_cap; i++) { -        node = hm->buckets[i]; -        while (node) { -            next = node->next; -            fn(node->key, node->value); -            node = next; -        } -    } +void +hashmap_destroy(struct hashmap *hm, hashmap_cb cb) +{ +	HASHMAP_WALK(hm, cb(node->key, node->value), free(node)); + +	free(hm->buckets); +	free(hm);  }  void  hashmap_free(struct hashmap *hm)  { -    struct node *node; -    struct node *next; - -    for (int i=0; i < hm->cur_cap; i++) { -        node = hm->buckets[i]; -        while (node) { -            next = node->next; -            free(node);             -            node = next; -        } -    } +	HASHMAP_WALK(hm, free(node));  	free(hm->buckets); -    free(hm); +	free(hm);  } | 
