AVTree
[Data Structures]

Low complexity tree container. More...


Functions

void * av_tree_find (const struct AVTreeNode *root, void *key, int(*cmp)(void *key, const void *b), void *next[2])
 Find an element.
void * av_tree_insert (struct AVTreeNode **rootp, void *key, int(*cmp)(void *key, const void *b), struct AVTreeNode **next)
 Insert or remove an element.
void av_tree_destroy (struct AVTreeNode *t)
void av_tree_enumerate (struct AVTreeNode *t, void *opaque, int(*cmp)(void *opaque, void *elem), int(*enu)(void *opaque, void *elem))
 Apply enu(opaque, &elem) to all the elements in the tree in a given range.

Variables

const int av_tree_node_size


Detailed Description

Low complexity tree container.

Insertion, removal, finding equal, largest which is smaller than and smallest which is larger than, all have O(log n) worst case complexity.


Function Documentation

void av_tree_destroy ( struct AVTreeNode t  ) 

Definition at line 134 of file tree.c.

Referenced by av_tree_destroy(), ff_nut_free_sp(), and uninit().

void av_tree_enumerate ( struct AVTreeNode t,
void *  opaque,
int(*)(void *opaque, void *elem)  cmp,
int(*)(void *opaque, void *elem)  enu 
)

Apply enu(opaque, &elem) to all the elements in the tree in a given range.

Parameters:
cmp a comparison function that returns < 0 for a element below the range, > 0 for a element above the range and == 0 for a element inside the range
Note:
The cmp function should use the same ordering used to construct the tree.

Definition at line 143 of file tree.c.

Referenced by av_tree_enumerate(), ff_nut_free_sp(), and uninit().

void* av_tree_find ( const struct AVTreeNode root,
void *  key,
int(*)(void *key, const void *b)  cmp,
void *  next[2] 
)

Find an element.

Parameters:
root a pointer to the root node of the tree
next If next is not NULL, then next[0] will contain the previous element and next[1] the next element. If either does not exist, then the corresponding entry in next is unchanged.
Returns:
An element with cmp(key, elem)==0 or NULL if no such element exists in the tree.

void* av_tree_insert ( struct AVTreeNode **  rootp,
void *  key,
int(*)(void *key, const void *b)  cmp,
struct AVTreeNode **  next 
)

Insert or remove an element.

If *next is NULL, then the supplied element will be removed if it exists. If *next is not NULL, then the supplied element will be inserted, unless it already exists in the tree.

Parameters:
rootp A pointer to a pointer to the root node of the tree; note that the root node can change during insertions, this is required to keep the tree balanced.
next Used to allocate and free AVTreeNodes. For insertion the user must set it to an allocated and zeroed object of at least av_tree_node_size bytes size. av_tree_insert() will set it to NULL if it has been consumed. For deleting elements *next is set to NULL by the user and av_tree_node_size() will set it to the AVTreeNode which was used for the removed element. This allows the use of flat arrays, which have lower overhead compared to many malloced elements. You might want to define a function like:
             void *tree_insert(struct AVTreeNode **rootp, void *key, int (*cmp)(void *key, const void *b), AVTreeNode **next){
                 if(!*next) *next= av_mallocz(av_tree_node_size);
                 return av_tree_insert(rootp, key, cmp, next);
             }
             void *tree_remove(struct AVTreeNode **rootp, void *key, int (*cmp)(void *key, const void *b, AVTreeNode **next)){
                 av_freep(next);
                 return av_tree_insert(rootp, key, cmp, next);
             }
Returns:
If no insertion happened, the found element; if an insertion or removal happened, then either key or NULL will be returned. Which one it is depends on the tree state and the implementation. You should make no assumptions that it's one or the other in the code.

Definition at line 51 of file tree.c.

Referenced by av_tree_insert(), ff_nut_add_sp(), and load_glyph().


Variable Documentation

const int av_tree_node_size

Definition at line 30 of file tree.c.

Referenced by ff_nut_add_sp(), and load_glyph().


Generated on Fri Oct 26 02:43:54 2012 for FFmpeg by  doxygen 1.5.8