begin tree implementation
git-svn-id: https://svn.musicpd.org/mpd/trunk@2984 09075e82-0dd4-0310-85a5-a0d7c8717e4f
This commit is contained in:
parent
fad348b285
commit
93b27fe831
52
src/tree.c
Normal file
52
src/tree.c
Normal file
@ -0,0 +1,52 @@
|
|||||||
|
#include "tree.h"
|
||||||
|
|
||||||
|
static inline TreeNode * newTreeNode() {
|
||||||
|
TreeNode * ret = malloc(sizeof(TreeNode));
|
||||||
|
|
||||||
|
ret->data[0] = NULL;
|
||||||
|
ret->data[1] = NULL;
|
||||||
|
|
||||||
|
ret->children[0] = NULL;
|
||||||
|
ret->children[1] = NULL;
|
||||||
|
ret->children[2] = NULL;
|
||||||
|
|
||||||
|
return ret;
|
||||||
|
}
|
||||||
|
|
||||||
|
static inline void freeTreeNode(TreeNode * node) {
|
||||||
|
free(node);
|
||||||
|
}
|
||||||
|
|
||||||
|
Tree * newTree(TreeFreeDataFunc * freeFunc, TreeCompareDataFunc * compareFunc) {
|
||||||
|
Tree * ret = malloc(sizeof(Tree));
|
||||||
|
|
||||||
|
ret->headNode = NULL;
|
||||||
|
ret->freeFunc = freeFunc;
|
||||||
|
ret->compareFunc = compareFunc;
|
||||||
|
|
||||||
|
return ret;
|
||||||
|
}
|
||||||
|
|
||||||
|
void freeTree(Tree * tree) {
|
||||||
|
TreeIterator * iter = newTreeIterator(tree, POSTORDER);
|
||||||
|
|
||||||
|
TreeNode * node;
|
||||||
|
|
||||||
|
if(data->freeFunc) {
|
||||||
|
void * data;
|
||||||
|
|
||||||
|
while( ( data = nextTreeIterator(iter) ) ) {
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
freeTreeIterator(iter);
|
||||||
|
|
||||||
|
iter = newTreeIterator(tree, POSTORDER);
|
||||||
|
}
|
||||||
|
|
||||||
|
while( ( node = nextNodeTreeIterator(iter) ) ) {
|
||||||
|
freeTreeNode(node);
|
||||||
|
}
|
||||||
|
|
||||||
|
freeTreeIterator(iter);
|
||||||
|
}
|
Loading…
Reference in New Issue
Block a user