make text lookup use a simple linked lists rather than an unnecessary array of pointers

This commit is contained in:
jp9000 2013-12-07 11:23:49 -07:00
parent 9b882c097b
commit 5d3f3e0d1b
2 changed files with 29 additions and 31 deletions

View file

@ -799,7 +799,7 @@ void obs_source_output_audio(obs_source_t source,
pthread_mutex_unlock(&source->filter_mutex);
}
/*
/*
* Ensures that cached frames are displayed on time. If multiple frames
* were cached between renders, then releases the unnecessary frames and uses
* the frame with the closest timing.

View file

@ -22,7 +22,6 @@
******************************************************************************/
#include "dstr.h"
#include "darray.h"
#include "text-lookup.h"
#include "lexer.h"
#include "platform.h"
@ -44,37 +43,42 @@ static inline void text_leaf_destroy(struct text_leaf *leaf)
struct text_node {
struct dstr str;
struct darray subnodes; /* struct text_node * */
struct text_node *first_subnode;
struct text_leaf *leaf;
struct text_node *next;
};
static void text_node_destroy(struct text_node *node)
{
struct text_node **subnodes;
size_t i;
struct text_node *subnode;
if (!node)
return;
subnodes = node->subnodes.array;
subnode = node->first_subnode;
while (subnode) {
struct text_node *destroy_node = subnode;
subnode = subnode->next;
text_node_destroy(destroy_node);
}
dstr_free(&node->str);
for (i = 0; i < node->subnodes.num; i++)
text_node_destroy(subnodes[i]);
if (node->leaf)
text_leaf_destroy(node->leaf);
darray_free(&node->subnodes);
bfree(node);
}
static struct text_node *text_node_bychar(struct text_node *node, char ch)
{
size_t i;
struct text_node **subnodes = node->subnodes.array;
struct text_node *subnode = node->first_subnode;
for (i = 0; i < node->subnodes.num; i++) {
struct text_node *child = subnodes[i];
if (!dstr_isempty(&child->str) && child->str.array[0] == ch)
return child;
while (subnode) {
if (!dstr_isempty(&subnode->str) && subnode->str.array[0] == ch)
return subnode;
subnode = subnode->next;
}
return NULL;
@ -83,25 +87,18 @@ static struct text_node *text_node_bychar(struct text_node *node, char ch)
static struct text_node *text_node_byname(struct text_node *node,
const char *name)
{
size_t i;
struct text_node **subnodes = node->subnodes.array;
struct text_node *subnode = node->first_subnode;
for (i = 0; i < node->subnodes.num; i++) {
struct text_node *child = subnodes[i];
if (astrcmpi_n(child->str.array, name, child->str.len) == 0)
return child;
while (subnode) {
if (astrcmpi_n(subnode->str.array, name, subnode->str.len) == 0)
return subnode;
subnode = subnode->next;
}
return NULL;
}
static inline void text_node_removesubnode(struct text_node *node,
struct text_node *child, size_t idx)
{
darray_erase(sizeof(struct text_node*), &node->subnodes, idx);
text_node_destroy(child);
}
/* ------------------------------------------------------------------------- */
struct text_lookup {
@ -118,7 +115,8 @@ static void lookup_createsubnode(const char *lookup_val,
new->leaf = leaf;
dstr_copy(&new->str, lookup_val);
darray_push_back(sizeof(struct text_node*), &node->subnodes, &new);
new->next = node->first_subnode;
node->first_subnode = new;
}
static void lookup_splitnode(const char *lookup_val, size_t len,
@ -129,10 +127,10 @@ static void lookup_splitnode(const char *lookup_val, size_t len,
dstr_copy(&split->str, node->str.array+len);
split->leaf = node->leaf;
darray_move(&split->subnodes, &node->subnodes);
split->first_subnode = node->first_subnode;
node->first_subnode = split;
dstr_resize(&node->str, len);
darray_push_back(sizeof(struct text_node), &node->subnodes, &split);
if (lookup_val[len] != 0) {
node->leaf = NULL;