]> pd.if.org Git - nbds/blobdiff - include/list.h
work in progress
[nbds] / include / list.h
index e4cba2d93d7f3344497491159990d00b4f209473..c6db953ca43abe1761fb2af839a0f44fe9c897cd 100644 (file)
@@ -6,23 +6,23 @@
 typedef struct ll list_t;
 typedef struct ll_iter ll_iter_t;
 
-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);
+map_val_t  ll_cas     (list_t *ll, map_key_t key, map_val_t expected_val, map_val_t new_val);
+map_val_t  ll_lookup  (list_t *ll, map_key_t key);
+map_val_t  ll_remove  (list_t *ll, map_key_t key);
+size_t     ll_count   (list_t *ll);
+void       ll_print   (list_t *ll, int verbose);
+void       ll_free    (list_t *ll);
+map_key_t  ll_min_key (list_t *sl);
 
-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);
+ll_iter_t * ll_iter_begin (list_t *ll, map_key_t key);
+map_val_t   ll_iter_next  (ll_iter_t *iter, map_key_t *key_ptr);
+void        ll_iter_free  (ll_iter_t *iter);
 
-static const map_impl_t ll_map_impl = { 
+static const map_impl_t MAP_IMPL_LL = { 
     (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
+    (map_count_t)ll_count, (map_print_t)ll_print, (map_free_t)ll_free, (map_iter_begin_t)ll_iter_begin,
+    (map_iter_next_t)ll_iter_next, (map_iter_free_t)ll_iter_free
 };
 
 #endif//LIST_H