2011-11-29 12:49:19 +04:00
|
|
|
/* vim: tabstop=4 shiftwidth=4 noexpandtab
|
|
|
|
*
|
|
|
|
* General-purpose tree implementation
|
|
|
|
*/
|
|
|
|
#ifndef TREE_H
|
|
|
|
#define TREE_H
|
|
|
|
|
|
|
|
#include <system.h>
|
|
|
|
#include <list.h>
|
|
|
|
|
|
|
|
typedef struct tree_node {
|
|
|
|
void * value;
|
|
|
|
list_t * children;
|
|
|
|
struct tree_node * parent;
|
|
|
|
} tree_node_t;
|
|
|
|
|
|
|
|
typedef struct {
|
|
|
|
size_t nodes;
|
|
|
|
tree_node_t * root;
|
|
|
|
} tree_t;
|
|
|
|
|
2011-12-08 06:58:47 +04:00
|
|
|
typedef uint8_t (*tree_comparator_t) (void *, void *);
|
|
|
|
|
2011-11-29 12:49:19 +04:00
|
|
|
tree_t * tree_create();
|
|
|
|
void tree_set_root(tree_t * tree, void * value);
|
|
|
|
void tree_node_destroy(tree_node_t * node);
|
|
|
|
void tree_destroy(tree_t * tree);
|
|
|
|
void tree_free(tree_t * tree);
|
|
|
|
tree_node_t * tree_node_create(void * value);
|
|
|
|
void tree_node_insert_child_node(tree_t * tree, tree_node_t * parent, tree_node_t * node);
|
|
|
|
tree_node_t * tree_node_insert_child(tree_t * tree, tree_node_t * parent, void * value);
|
|
|
|
tree_node_t * tree_node_find_parent(tree_node_t * haystack, tree_node_t * needle);
|
|
|
|
void tree_node_parent_remove(tree_t * tree, tree_node_t * parent, tree_node_t * node);
|
|
|
|
void tree_node_remove(tree_t * tree, tree_node_t * node);
|
2011-11-29 16:52:26 +04:00
|
|
|
void tree_remove(tree_t * tree, tree_node_t * node);
|
2011-12-08 06:58:47 +04:00
|
|
|
tree_node_t * tree_find(tree_t * tree, void * value, tree_comparator_t comparator);
|
|
|
|
void tree_break_off(tree_t * tree, tree_node_t * node);
|
|
|
|
|
2011-11-29 12:49:19 +04:00
|
|
|
|
|
|
|
#endif
|