00001
00002
00003
00004
00005
00006
00007
00008
00009
00010
00011
00012
00013
00014
00015
00016
00017
00018
00019
00020
00021
00022 #ifndef RBT_I64_H
00023 #define RBT_I64_H
00024
00025 #include "rbt_common.h"
00026
00027 struct rbt_i64_node {
00028 int64_t key;
00029 void *data;
00030 };
00031
00032 typedef struct rbt_i64_node rbt_i64_node_t;
00033
00034 #define rbt_i64_node_key(np) (((struct rbt_i64_node *)(rbt_node_ptr(np)->_node))->key)
00035 #define rbt_i64_node_data(np) (((struct rbt_i64_node *)(rbt_node_ptr(np)->_node))->data)
00036
00037 rbt_t *rbt_i64_new (void);
00038 void rbt_i64_free (rbt_t *rbt);
00039 void rbt_i64_free_cb (rbt_t *rbt, void (*callback)(rbt_i64_node_t *));
00040
00041 int rbt_i64_add(rbt_t *rbt, int64_t key, void *data, void **coll);
00042 void *rbt_i64_rep(rbt_t *rbt, int64_t key, void *data);
00043 int rbt_i64_del(rbt_t *rbt, int64_t key, void **n);
00044 int rbt_i64_get(rbt_t *rbt, int64_t key, void **data);
00045
00046 int rbt_i64_walk_preorder(rbt_t *rbt, int (*callback)(rbt_i64_node_t *), rbt_walk_t flags);
00047 int rbt_i64_walk_inorder(rbt_t *rbt, int (*callback)(rbt_i64_node_t *), rbt_walk_t flags);
00048 int rbt_i64_walk_postorder(rbt_t *rbt, int (*callback)(rbt_i64_node_t *), rbt_walk_t flags);
00049 int rbt_i64_walk_levelorder(rbt_t *rbt, int (*callback)(rbt_i64_node_t *), rbt_walk_t flags);
00050 int rbt_i64_walk(rbt_t *rbt, rbt_walk_t type, int (*callback)(rbt_i64_node_t *));
00051 size_t rbt_i64_size(rbt_t *rbt);
00052
00053 #endif