X-Git-Url: https://pd.if.org/git/?p=nbds;a=blobdiff_plain;f=map%2Flist.c;h=9e66787c2be4ef54c4c9b043b691b203d71d820f;hp=a94d2d00594274b2e2b7b661b697667ab8802d26;hb=f3a053a46bbb4ba460bcff0920b93dfc8263e02e;hpb=dbcd4739e02b8e774e28b752c412d7e2f242cd47 diff --git a/map/list.c b/map/list.c index a94d2d0..9e66787 100644 --- a/map/list.c +++ b/map/list.c @@ -13,11 +13,13 @@ #include "list.h" #include "mem.h" -typedef struct node { +typedef struct ll_iter node_t; + +struct ll_iter { void *key; uint64_t val; - struct node *next; -} node_t; + node_t *next; +}; struct ll { node_t *head; @@ -304,3 +306,30 @@ void ll_print (list_t *ll) { } printf("\n"); } + +ll_iter_t *ll_iter_start (list_t *ll, void *key) { + node_t *item; + find_pred(NULL, &item, ll, key, FALSE); + return item; +} + +ll_iter_t *ll_iter_next (ll_iter_t *iter) { + assert(iter); + if (EXPECT_FALSE(!iter)) + return NULL; + + node_t *next = iter->next; + while (next != NULL && IS_TAGGED(next->next, TAG1)) { + next = (node_t *)STRIP_TAG(next->next, TAG1); + } + + return next; +} + +uint64_t ll_iter_val (ll_iter_t *iter) { + return iter->val; +} + +void *ll_iter_key (ll_iter_t *iter) { + return iter->key; +}