#ifndef STRMAP_H #define STRMAP_H #include "hashmap.h" struct strmap { struct hashmap map; unsigned int strdup_strings:1; }; struct strmap_entry { struct hashmap_entry ent; const char *key; void *value; }; int cmp_strmap_entry(const void *hashmap_cmp_fn_data, const struct hashmap_entry *entry1, const struct hashmap_entry *entry2, const void *keydata); #define STRMAP_INIT { \ .map = HASHMAP_INIT(cmp_strmap_entry, NULL), \ .strdup_strings = 1, \ } /* * Initialize the members of the strmap. Any keys added to the strmap will * be strdup'ed with their memory managed by the strmap. */ void strmap_init(struct strmap *map); /* * Same as strmap_init, but for those who want to control the memory management * carefully instead of using the default of strdup_strings=1. */ void strmap_init_with_options(struct strmap *map, int strdup_strings); /* * Remove all entries from the map, releasing any allocated resources. */ void strmap_clear(struct strmap *map, int free_values); /* * Similar to strmap_clear() but leaves map->map->table allocated and * pre-sized so that subsequent uses won't need as many rehashings. */ void strmap_partial_clear(struct strmap *map, int free_values); /* * Insert "str" into the map, pointing to "data". * * If an entry for "str" already exists, its data pointer is overwritten, and * the original data pointer returned. Otherwise, returns NULL. */ void *strmap_put(struct strmap *map, const char *str, void *data); /* * Return the strmap_entry mapped by "str", or NULL if there is not such * an item in map. */ struct strmap_entry *strmap_get_entry(struct strmap *map, const char *str); /* * Return the data pointer mapped by "str", or NULL if the entry does not * exist. */ void *strmap_get(struct strmap *map, const char *str); /* * Return non-zero iff "str" is present in the map. This differs from * strmap_get() in that it can distinguish entries with a NULL data pointer. */ int strmap_contains(struct strmap *map, const char *str); /* * Remove the given entry from the strmap. If the string isn't in the * strmap, the map is not altered. */ void strmap_remove(struct strmap *map, const char *str, int free_value); /* * Return how many entries the strmap has. */ static inline unsigned int strmap_get_size(struct strmap *map) { return hashmap_get_size(&map->map); } /* * Return whether the strmap is empty. */ static inline int strmap_empty(struct strmap *map) { return strmap_get_size(map) == 0; } /* * iterate through @map using @iter, @var is a pointer to a type strmap_entry */ #define strmap_for_each_entry(mystrmap, iter, var) \ hashmap_for_each_entry(&(mystrmap)->map, iter, var, ent) #endif /* STRMAP_H */