rbtree

view src/rbtree.h @ 0:6621337b6378

red-black tree lib
author John Tsiombikas <nuclear@mutantstargoat.com>
date Sun, 09 Oct 2011 07:48:14 +0300
parents
children 3b219820ebe8
line source
1 #ifndef RBTREE_H_
2 #define RBTREE_H_
4 struct rbtree;
7 struct rbnode {
8 void *key, *data;
9 int red;
10 struct rbnode *left, *right;
11 struct rbnode *next; /* for iterator stack */
12 };
15 typedef void *(*rb_alloc_func_t)(size_t);
16 typedef void (*rb_free_func_t)(void*);
18 typedef int (*rb_cmp_func_t)(void*, void*);
19 typedef void (*rb_del_func_t)(struct rbnode*, void*);
21 #define RB_KEY_ADDR (rb_cmp_func_t)(0)
22 #define RB_KEY_INT (rb_cmp_func_t)(1)
23 #define RB_KEY_STRING (rb_cmp_func_t)(3)
25 typedef struct rbnode* rbiter_t;
27 #ifdef __cplusplus
28 extern "C" {
29 #endif
31 struct rbtree *rb_create(rb_cmp_func_t cmp_func);
32 void rb_free(struct rbtree *rb);
34 int rb_init(struct rbtree *rb, rb_cmp_func_t cmp_func);
35 void rb_destroy(struct rbtree *rb);
37 void rb_set_allocator(struct rbtree *rb, rb_alloc_func_t alloc, rb_free_func_t free);
38 void rb_set_compare_func(struct rbtree *rb, rb_cmp_func_t func);
39 void rb_set_delete_func(struct rbtree *rb, rb_del_func_t func, void *cls);
41 int rb_size(struct rbtree *rb);
43 int rb_insert(struct rbtree *rb, void *key, void *data);
44 int rb_inserti(struct rbtree *rb, int key, void *data);
46 int rb_delete(struct rbtree *rb, void *key);
47 int rb_deletei(struct rbtree *rb, int key);
49 void *rb_find(struct rbtree *rb, void *key);
50 void *rb_findi(struct rbtree *rb, int key);
52 void rb_foreach(struct rbtree *rb, void (*func)(struct rbnode*, void*), void *cls);
54 struct rbnode *rb_root(struct rbtree *rb);
56 void rb_begin(struct rbtree *rb);
57 struct rbnode *rb_node_next(struct rbtree *rb);
59 void *rb_node_key(struct rbnode *node);
60 int rb_node_keyi(struct rbnode *node);
61 void *rb_node_data(struct rbnode *node);
63 #ifdef __cplusplus
64 }
65 #endif
68 #endif /* RBTREE_H_ */