Archived
1
0
Fork 0

rbtree: move delete_fn from the structure to argument.

This commit is contained in:
Henrik Hautakoski 2011-02-01 11:51:54 +01:00
parent ae3dec912a
commit b5f0c3117c
5 changed files with 10 additions and 14 deletions

View file

@ -25,9 +25,6 @@ Structure that holds a tree of nodes
`root`::
Pointer to the node that is the root of the tree.
`delete_fn`::
Pointer to the function that should handle the delete routines for the `key` pointer.
`cmp_fn`::
Pointer to the function that is used to compare two `key` pointers. +
Shall return a value greater than zero if 'ptr1' > 'ptr2', a value less than zero if 'ptr1' < 'ptr2' and zero if 'ptr1' == 'ptr2'.
@ -50,7 +47,7 @@ NOTE: The memory pointed to by the 'key' pointer is *not* copied so you must ens
`rbtree_free()`::
Deletes the whole tree. if provided, calls `rbtree->delete_fn` for every node.
Deletes the whole tree. if provided, calls 'free_fn' for every node.
`rbtree_walk()`::

View file

@ -136,8 +136,8 @@ int inotify_unmap_path(const char *path) {
void inotify_unmap_all() {
rbtree_free(&tree_path_wd);
rbtree_free(&tree_wd_paths);
rbtree_free(&tree_path_wd, xfree);
rbtree_free(&tree_wd_paths, wd_free);
}
int inotify_map_get_wd(const char *path) {

View file

@ -185,12 +185,12 @@ void rbtree_walk(rbtree *tree, void (*action)(const void *)) {
#endif
}
void rbtree_free(rbtree *tree) {
void rbtree_free(rbtree *tree, void (*free_fn)(void *)) {
if (!tree)
return;
node_dealloc(tree->root, tree->delete_fn);
node_dealloc(tree->root, free_fn);
tree->root = NULL;
#ifdef __DEBUG__

View file

@ -16,11 +16,10 @@
typedef struct {
struct _rbn *root;
/* user defined operations */
void (*delete_fn)(void *);
int (*cmp_fn)(const void *, const void *);
} rbtree;
#define RBTREE_INIT(delete, update, cmp) { NULL, delete, cmp}
#define RBTREE_INIT(delete, update, cmp) { NULL, cmp }
int rbtree_is_empty(rbtree *tree);
@ -28,7 +27,7 @@ void* rbtree_search(rbtree *tree, const void *key);
void rbtree_walk(rbtree *tree, void (*action)(const void *));
void rbtree_free(rbtree *tree);
void rbtree_free(rbtree *tree, void (*free_fn)(void *));
int rbtree_insert(rbtree *tree, const void *key);

View file

@ -12,7 +12,7 @@ static int vcmp(const void *a, const void *b);
static void vdelete(void *ptr);
/* data */
static rbtree tree = RBTREE_INIT(vdelete, NULL, vcmp);
static rbtree tree = RBTREE_INIT(NULL, NULL, vcmp);
static int keyref[NODES];
static int vcmp(const void *a, const void *b) {
@ -77,7 +77,7 @@ static void teardown() {
int i;
rbtree_free(&tree);
rbtree_free(&tree, vdelete);
for(i=0; i < NODES; i++)
keyref[i] = -1;
@ -89,7 +89,7 @@ void test_rbtree_is_empty() {
assert(rbtree_is_empty(&tree) == 0);
rbtree_free(&tree);
rbtree_free(&tree, vdelete);
assert(rbtree_is_empty(&tree));