]> pd.if.org Git - nbds/blobdiff - include/list.h
add iterators to hashtable, skiplist, and list
[nbds] / include / list.h
index 7eeda46aff1e65ffa30accecd26713b9644f40cd..e4cba2d93d7f3344497491159990d00b4f209473 100644 (file)
@@ -1,19 +1,28 @@
 #ifndef LIST_H
 #define LIST_H
 
-#include "datatype.h"
 #include "map.h"
 
 typedef struct ll list_t;
+typedef struct ll_iter ll_iter_t;
 
-extern map_type_t MAP_TYPE_LIST;
+list_t * ll_alloc   (const datatype_t *key_type);
+uint64_t ll_cas     (list_t *ll, void *key, uint64_t expected_val, uint64_t new_val);
+uint64_t ll_lookup  (list_t *ll, void *key);
+uint64_t ll_remove  (list_t *ll, void *key);
+uint64_t ll_count   (list_t *ll);
+void     ll_print   (list_t *ll);
+void     ll_free    (list_t *ll);
+void *   ll_min_key (list_t *sl);
 
-list_t * ll_alloc  (const datatype_t *key_type);
-uint64_t ll_cas    (list_t *ll, void *key, uint64_t expected_val, uint64_t new_val);
-uint64_t ll_lookup (list_t *ll, void *key);
-uint64_t ll_remove (list_t *ll, void *key);
-uint64_t ll_count  (list_t *ll);
-void     ll_print  (list_t *ll);
-void     ll_free   (list_t *ll);
+ll_iter_t *ll_iter_start (list_t *ll, void *key);
+ll_iter_t *ll_iter_next  (ll_iter_t *iter);
+uint64_t   ll_iter_val   (ll_iter_t *iter);
+void *     ll_iter_key   (ll_iter_t *iter);
+
+static const map_impl_t ll_map_impl = { 
+    (map_alloc_t)ll_alloc, (map_cas_t)ll_cas, (map_get_t)ll_lookup, (map_remove_t)ll_remove, 
+    (map_count_t)ll_count, (map_print_t)ll_print, (map_free_t)ll_free
+};
 
 #endif//LIST_H