add 2-3 tree header file
git-svn-id: https://svn.musicpd.org/mpd/trunk@2982 09075e82-0dd4-0310-85a5-a0d7c8717e4f
This commit is contained in:
parent
c5a31e1a9c
commit
fbc37e7db4
51
src/tree.h
Normal file
51
src/tree.h
Normal file
@ -0,0 +1,51 @@
|
||||
#ifndef TREE_H
|
||||
#define TREE_H
|
||||
|
||||
typedef struct _TreeNode {
|
||||
void * data[2];
|
||||
struct _TreeNode * children[3];
|
||||
struct _TreeNode * parent;
|
||||
} TreeNode;
|
||||
|
||||
typedef struct _Tree {
|
||||
TreeNode headNode;
|
||||
TreeFreeDataFunc * freeFunc;
|
||||
TreeCompareDataFunc * compareFunc;
|
||||
} Tree;
|
||||
|
||||
typedef enum _TreeIteratorType {
|
||||
PREORDER,
|
||||
INORDER,
|
||||
POSTORDER
|
||||
} TreeIteratorType;
|
||||
|
||||
typedef struct _TreeIterator {
|
||||
Data * data;
|
||||
/* private data */
|
||||
TreeIteratorType type;
|
||||
TreeNode * currentNode;
|
||||
int pos;
|
||||
} TreeIterator;
|
||||
|
||||
typedef int TreeCompareDataFunc(void * left, void * right);
|
||||
|
||||
typedef int TreeFreeDataFunc(void * data);
|
||||
|
||||
Tree * newTree(TreeFreeDataFunc * freeFunc, TreeCompareDataFunc * compareFunc);
|
||||
|
||||
void freeTree(Tree * tree);
|
||||
|
||||
int insertInTree(Tree * tree, void * data);
|
||||
|
||||
int deleteFromTree(Tree * tree, void * needle);
|
||||
|
||||
void * findInTree(Tree * tree, void * needle);
|
||||
|
||||
TreeIterator * newTreeIterator(Tree * tree, TreeIteratorType type);
|
||||
|
||||
/* will return the same pointer passed in on success
|
||||
* if NULL is returned, this indicates the end of tree
|
||||
*/
|
||||
TreeIterator * nextTreeIterator(TreeIterator * iter);
|
||||
|
||||
#endif // TREE_H
|
Loading…
Reference in New Issue
Block a user