X-Git-Url: https://pd.if.org/git/?p=nbds;a=blobdiff_plain;f=include%2Fhashtable.h;fp=include%2Fhashtable.h;h=5ae84c11db2d670df7c44523cbf02bf2b391ee97;hp=9a32abc94746fc2bb966013572f7b209c688af4f;hb=f3a053a46bbb4ba460bcff0920b93dfc8263e02e;hpb=dbcd4739e02b8e774e28b752c412d7e2f242cd47 diff --git a/include/hashtable.h b/include/hashtable.h index 9a32abc..5ae84c1 100644 --- a/include/hashtable.h +++ b/include/hashtable.h @@ -4,6 +4,7 @@ #include "map.h" typedef struct ht hashtable_t; +typedef struct ht_iter ht_iter_t; hashtable_t *ht_alloc (const datatype_t *key_type); uint64_t ht_cas (hashtable_t *ht, void *key, uint64_t expected_val, uint64_t val); @@ -13,6 +14,12 @@ uint64_t ht_count (hashtable_t *ht); void ht_print (hashtable_t *ht); void ht_free (hashtable_t *ht); +ht_iter_t *ht_iter_start (hashtable_t *ht, void *key); +ht_iter_t *ht_iter_next (ht_iter_t *iter); +uint64_t ht_iter_val (ht_iter_t *iter); +uint64_t ht_iter_key (ht_iter_t *iter); +void ht_iter_free (ht_iter_t *iter); + static const map_impl_t ht_map_impl = { (map_alloc_t)ht_alloc, (map_cas_t)ht_cas, (map_get_t)ht_get, (map_remove_t)ht_remove, (map_count_t)ht_count, (map_print_t)ht_print, (map_free_t)ht_free