X-Git-Url: http://git.archive.openwrt.org/?p=project%2Flibubox.git;a=blobdiff_plain;f=avl.h;h=c46859723ff1418d05ba2bab52ee5796da753f1b;hp=a563716e1d5f43fd71e4931939176863e101e8ca;hb=213122a0830e1ba3a05013b5cb5d17c49af13282;hpb=677e7bc0b332a09fde6142119f42e5bac11979d3 diff --git a/avl.h b/avl.h index a563716..c468597 100644 --- a/avl.h +++ b/avl.h @@ -45,7 +45,6 @@ #include #include "list.h" -#include "list_compat.h" /* Support for OLSR.org linker symbol export */ #define EXPORT(sym) sym @@ -62,7 +61,7 @@ struct avl_node { * this must be the first element of an avl_node to * make casting for lists easier */ - struct list_entity list; + struct list_head list; /** * Pointer to parent node in tree, NULL if root node @@ -82,7 +81,7 @@ struct avl_node { /** * pointer to key of node */ - void *key; + const void *key; /** * balance state of AVL tree (0,-1,+1) @@ -113,7 +112,7 @@ struct avl_tree { * Head of linked list node for supporting easy iteration * and multiple elments with the same key. */ - struct list_entity list_head; + struct list_head list_head; /** * pointer to the root node of the avl tree, NULL if tree is empty @@ -154,6 +153,18 @@ enum avl_find_mode { AVL_FIND_GREATEREQUAL }; +#define AVL_TREE_INIT(_name, _comp, _allow_dups, _cmp_ptr) \ + { \ + .list_head = LIST_HEAD_INIT(_name.list_head), \ + .comp = _comp, \ + .allow_dups = _allow_dups, \ + .cmp_ptr = _cmp_ptr \ + } + +#define AVL_TREE(_name, _comp, _allow_dups, _cmp_ptr) \ + struct avl_tree _name = \ + AVL_TREE_INIT(_name, _comp, _allow_dups, _cmp_ptr) + void EXPORT(avl_init)(struct avl_tree *, avl_tree_comp, bool, void *); struct avl_node *EXPORT(avl_find)(const struct avl_tree *, const void *); struct avl_node *EXPORT(avl_find_greaterequal)(const struct avl_tree *tree, const void *key); @@ -267,7 +278,7 @@ __avl_find_element(const struct avl_tree *tree, const void *key, size_t offset, * (automatically converted to type 'element') */ #define avl_first_element(tree, element, node_member) \ - container_of((tree)->list_head.next, typeof(*(element)), node_member) + container_of((tree)->list_head.next, typeof(*(element)), node_member.list) /** * @param tree pointer to tree @@ -279,7 +290,7 @@ __avl_find_element(const struct avl_tree *tree, const void *key, size_t offset, * (automatically converted to type 'element') */ #define avl_last_element(tree, element, node_member) \ - container_of((tree)->list_head.prev, typeof(*(element)), node_member) + container_of((tree)->list_head.prev, typeof(*(element)), node_member.list) /** * This function must not be called for the last element of @@ -292,7 +303,7 @@ __avl_find_element(const struct avl_tree *tree, const void *key, size_t offset, * (automatically converted to type 'element') */ #define avl_next_element(element, node_member) \ - container_of((&(element)->node_member.list)->next, typeof(*(element)), node_member) + container_of((&(element)->node_member.list)->next, typeof(*(element)), node_member.list) /** * This function must not be called for the first element of @@ -305,7 +316,7 @@ __avl_find_element(const struct avl_tree *tree, const void *key, size_t offset, * (automatically converted to type 'element') */ #define avl_prev_element(element, node_member) \ - container_of((&(element)->node_member.list)->prev, typeof(*(element)), node_member) + container_of((&(element)->node_member.list)->prev, typeof(*(element)), node_member.list) /** * Loop over a block of elements of a tree, used similar to a for() command. @@ -534,7 +545,7 @@ __avl_find_element(const struct avl_tree *tree, const void *key, size_t offset, #define avl_remove_all_elements(tree, element, node_member, ptr) \ for (element = avl_first_element(tree, element, node_member), \ ptr = avl_next_element(element, node_member), \ - list_init_head(&(tree)->list_head), \ + INIT_LIST_HEAD(&(tree)->list_head), \ (tree)->root = NULL; \ (tree)->count > 0; \ element = ptr, ptr = avl_next_element(ptr, node_member), (tree)->count--)