From 112388f55d81e38b7ced860afa9056c2b439210f Mon Sep 17 00:00:00 2001 From: "7u83@mail.ru" <7u83@mail.ru@noemail.net> Date: Thu, 9 Apr 2015 14:30:04 +0000 Subject: [PATCH] AVL Tree iterator functions added. FossilOrigin-Name: d6c27caab24a9b6773796a05192a7bed9c8ed2e19d660ba6e1e6f0a80cbe0d6a --- src/capwap/avltree.h | 48 ++++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 48 insertions(+) diff --git a/src/capwap/avltree.h b/src/capwap/avltree.h index 8894944a..ebfbcc18 100644 --- a/src/capwap/avltree.h +++ b/src/capwap/avltree.h @@ -28,6 +28,9 @@ #include #include +#include + +#define AVLTREE_MAX_DEPTH 32 struct avlnode { void *data; @@ -44,6 +47,9 @@ struct avltree { int count; }; +typedef struct avltree * avltree_t; + + void avlnode_destroy(struct avltree *t, struct avlnode *n); struct avltree *avltree_create(int (*cmp) (const void *, const void *), @@ -83,6 +89,7 @@ static inline void avltree_destroy(struct avltree *t) + #define avltree_find(t,d) avltree_get(t,d) #define avltree_insert(t,d) avltree_add(t,d) //#define avltree_walk(t,dir) avltree_foreach(t,dir) @@ -93,4 +100,45 @@ static inline void avltree_destroy(struct avltree *t) #define avltree_foreach_from_asc(t,d,cb,priv) avltree_foreach_from_lr(t,(t)->root,d,cb,priv); +struct avliter{ + struct avlnode *stack[AVLTREE_MAX_DEPTH*2]; + + struct avlnode *cur; + int stack_ptr; + struct avlnode * root; + +}; +typedef struct avliter avliter_t; + + +void * avliter_next(avliter_t *i); + +void * avliter_seek_set(struct avliter *i) +{ + i->stack_ptr=0; + i->cur=i->root; + return avliter_next(i); +} + + +static inline void avliter_init(avliter_t *i, avltree_t t){ + i->root = t->root; + i->stack_ptr=0; +} + + +#define avliter_foreach_asc(iter,val) \ + while(NULL != (val = avliter_next(iter))) + +static inline void * avliter_get(avliter_t *i){ + if(!i->cur) + return NULL; + return i->cur->data; +} + + + + #endif + +