00001
00002
00003
00004
00005
00006
00007
00008
00009
00010
00011
00012
00013
00014
00015
00016
00017
00018
00019
00020
00021
00022 #ifndef RBT_STR_H
00023 #define RBT_STR_H
00024
00025 #include "rbt_common.h"
00026
00027 struct rbt_str_node {
00028 char *key;
00029 void *data;
00030 };
00031
00032 typedef struct rbt_str_node rbt_str_node_t;
00033
00034 static inline struct rbt_str_node *rbt_str_node(const struct rbt_node *np)
00035 {
00036 struct rbt_str_node *str_node = (struct rbt_str_node *)(rbt_node_ptr(np)->_node);
00037 return str_node;
00038 }
00039
00040 rbt_t *rbt_str_new (void);
00041 void rbt_str_free (rbt_t *rbt);
00042 void rbt_str_free_cb (rbt_t *rbt, void (*callback)(struct rbt_str_node *));
00043 void rbt_str_free_cb2 (rbt_t *rbt, void (*callback)(struct rbt_str_node *, void *user), void *user);
00044
00045 int rbt_str_add(rbt_t *rbt, char *key, void *data);
00046 void *rbt_str_rep(rbt_t *rbt, const char *key, void *data);
00047 int rbt_str_del(rbt_t *rbt, const char *key, void **n);
00048 int rbt_str_getnode(rbt_t *rbt, const char *key, struct rbt_str_node **node);
00049 int rbt_str_get(rbt_t *rbt, const char *key, void **data);
00050
00051 int rbt_str_walk_preorder(rbt_t *rbt, int (*callback)(struct rbt_str_node *), rbt_walk_t flags);
00052 int rbt_str_walk_inorder(rbt_t *rbt, int (*callback)(struct rbt_str_node *), rbt_walk_t flags);
00053 int rbt_str_walk_inorder2(rbt_t *rbt, int (*callback)(struct rbt_str_node *, void *), void *user, rbt_walk_t flags);
00054 int rbt_str_walk_postorder(rbt_t *rbt, int (*callback)(struct rbt_str_node *), rbt_walk_t flags);
00055 int rbt_str_walk_levelorder(rbt_t *rbt, int (*callback)(struct rbt_str_node *), rbt_walk_t flags);
00056 int rbt_str_walk(rbt_t *rbt, rbt_walk_t type, int (*callback)(struct rbt_str_node *));
00057 size_t rbt_str_size(rbt_t *rbt);
00058
00059 #endif