/*
 * pr_tree.h
 *
 * Interface for path reduction tree.
 * Copyright (C) 2001 Farooq Mela.
 *
 * $Id: pr_tree.h,v 1.2 2001/09/10 06:48:02 farooq Exp $
 */

#ifndef _PR_TREE_H_
#define _PR_TREE_H_

#include "dict.h"

BEGIN_DECL

struct pr_tree;
typedef struct pr_tree pr_tree;

pr_tree *pr_tree_new __P((dict_cmp_func key_cmp, dict_del_func key_del,
						  dict_del_func dat_del));
dict	*pr_dict_new __P((dict_cmp_func key_cmp, dict_del_func key_del,
						  dict_del_func dat_del));
void	 pr_tree_destroy __P((pr_tree *tree, int del));

int pr_tree_insert __P((pr_tree *tree, void *key, void *dat, int overwrite));
int pr_tree_probe __P((pr_tree *tree, void *key, void **dat));
void *pr_tree_search __P((pr_tree *tree, const void *key));
const void *pr_tree_csearch __P((const pr_tree *tree, const void *key));
int pr_tree_remove __P((pr_tree *tree, const void *key, int del));
void pr_tree_empty __P((pr_tree *tree, int del));
void pr_tree_walk __P((pr_tree *tree, dict_vis_func visit));
unsigned pr_tree_count __P((const pr_tree *tree));
unsigned pr_tree_height __P((const pr_tree *tree));
unsigned pr_tree_mheight __P((const pr_tree *tree));
unsigned pr_tree_pathlen __P((const pr_tree *tree));
const void *pr_tree_min __P((const pr_tree *tree));
const void *pr_tree_max __P((const pr_tree *tree));

struct pr_itor;
typedef struct pr_itor pr_itor;

pr_itor *pr_itor_new __P((pr_tree *tree));
dict_itor *pr_dict_itor_new __P((pr_tree *tree));
void pr_itor_destroy __P((pr_itor *tree));

int pr_itor_valid __P((const pr_itor *itor));
void pr_itor_invalidate __P((pr_itor *itor));
int pr_itor_next __P((pr_itor *itor));
int pr_itor_prev __P((pr_itor *itor));
int pr_itor_nextn __P((pr_itor *itor, unsigned count));
int pr_itor_prevn __P((pr_itor *itor, unsigned count));
int pr_itor_first __P((pr_itor *itor));
int pr_itor_last __P((pr_itor *itor));
int pr_itor_search __P((pr_itor *itor, const void *key));
const void *pr_itor_key __P((const pr_itor *itor));
void *pr_itor_data __P((pr_itor *itor));
const void *pr_itor_cdata __P((const pr_itor *itor));
int pr_itor_set_data __P((pr_itor *itor, void *dat, int del));
int pr_itor_remove __P((pr_itor *itor, int del));

END_DECL

#endif /* !_PR_TREE_H_ */


syntax highlighted by Code2HTML, v. 0.9.1