X-Git-Url: http://git.archive.openwrt.org/?p=project%2Fnetifd.git;a=blobdiff_plain;f=utils.h;h=99b1c0d2d8798e9427195d31dfc118be44d24e6a;hp=2866280b6173e9135b11318594049cb1c0f75fe5;hb=c6e1778d4429032087b36fb0dde2ae2fecf53b4a;hpb=9fe20c8cbc4249c13d6f305adc91f4bc695f7c23 diff --git a/utils.h b/utils.h index 2866280..99b1c0d 100644 --- a/utils.h +++ b/utils.h @@ -26,7 +26,6 @@ struct vlist_tree { struct avl_tree avl; vlist_update_cb update; - int key_offset; bool keep_old; bool no_delete; @@ -38,10 +37,7 @@ struct vlist_node { int version; }; -void __vlist_init(struct vlist_tree *tree, avl_tree_comp cmp, vlist_update_cb update, int offset); - -#define vlist_init(tree, cmp, update, type, node, key) \ - __vlist_init(tree, cmp, update, offsetof(type, key) - offsetof(type, node)) +void vlist_init(struct vlist_tree *tree, avl_tree_comp cmp, vlist_update_cb update); #define vlist_find(tree, name, element, node_member) \ avl_find_element(&(tree)->avl, name, element, node_member.avl) @@ -51,7 +47,7 @@ static inline void vlist_update(struct vlist_tree *tree) tree->version++; } -void vlist_add(struct vlist_tree *tree, struct vlist_node *node); +void vlist_add(struct vlist_tree *tree, struct vlist_node *node, void *key); void vlist_delete(struct vlist_tree *tree, struct vlist_node *node); void vlist_flush(struct vlist_tree *tree); void vlist_flush_all(struct vlist_tree *tree);