/*
 * rb_tree.h
 *
 * Definitions for red-black binary search tree.
 * Copyright (C) 2001 Farooq Mela.
 *
 * $Id: rb_tree.h,v 1.3 2001/09/10 06:49:35 farooq Exp $
 */

#ifndef _RB_TREE_H_
#define _RB_TREE_H_

#include "dict.h"

BEGIN_DECL

struct rb_tree;
typedef struct rb_tree rb_tree;

rb_tree	*rb_tree_new __P((dict_cmp_func key_cmp, dict_del_func key_del,
						  dict_del_func dat_del));
dict	*rb_dict_new __P((dict_cmp_func key_cmp, dict_del_func key_del,
						  dict_del_func dat_del));
void rb_tree_destroy __P((rb_tree *tree, int del));

int rb_tree_insert __P((rb_tree *tree, void *key, void *dat, int overwrite));
int rb_tree_probe __P((rb_tree *tree, void *key, void **dat));
void *rb_tree_search __P((rb_tree *tree, const void *key));
const void *rb_tree_csearch __P((const rb_tree *tree, const void *key));
int rb_tree_remove __P((rb_tree *tree, const void *key, int del));
void rb_tree_empty __P((rb_tree *tree, int del));
void rb_tree_walk __P((rb_tree *tree, dict_vis_func visit));
unsigned rb_tree_count __P((const rb_tree *tree));
unsigned rb_tree_height __P((const rb_tree *tree));
unsigned rb_tree_mheight __P((const rb_tree *tree));
unsigned rb_tree_pathlen __P((const rb_tree *tree));
const void *rb_tree_min __P((const rb_tree *tree));
const void *rb_tree_max __P((const rb_tree *tree));

struct rb_itor;
typedef struct rb_itor rb_itor;

rb_itor *rb_itor_new __P((rb_tree *tree));
dict_itor *rb_dict_itor_new __P((rb_tree *tree));
void rb_itor_destroy __P((rb_itor *tree));

int rb_itor_valid __P((const rb_itor *itor));
void rb_itor_invalidate __P((rb_itor *itor));
int rb_itor_next __P((rb_itor *itor));
int rb_itor_prev __P((rb_itor *itor));
int rb_itor_nextn __P((rb_itor *itor, unsigned count));
int rb_itor_prevn __P((rb_itor *itor, unsigned count));
int rb_itor_first __P((rb_itor *itor));
int rb_itor_last __P((rb_itor *itor));
int rb_itor_search __P((rb_itor *itor, const void *key));
const void *rb_itor_key __P((const rb_itor *itor));
void *rb_itor_data __P((rb_itor *itor));
const void *rb_itor_cdata __P((const rb_itor *itor));
int rb_itor_set_data __P((rb_itor *itor, void *dat, int del));
int rb_itor_remove __P((rb_itor *itor, int del));

END_DECL

#endif /* !_RB_TREE_H_ */


syntax highlighted by Code2HTML, v. 0.9.1