From 2638f42ecaf7be96702d81976a845292df336d9e Mon Sep 17 00:00:00 2001 From: Enno Rehling Date: Mon, 14 May 2012 17:02:15 -0700 Subject: [PATCH] putting the crit-bit tree to use. findingfunctions is faster this way than that hand-rolled list --- src/util/functions.c | 35 ++++++++++++++++------------------- 1 file changed, 16 insertions(+), 19 deletions(-) diff --git a/src/util/functions.c b/src/util/functions.c index 54d52444e..7e22e7293 100644 --- a/src/util/functions.c +++ b/src/util/functions.c @@ -19,35 +19,32 @@ OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. #include #include "functions.h" +#include + /* libc includes */ +#include #include #include -typedef struct function_list { - struct function_list *next; - pf_generic fun; - const char *name; -} function_list; - -static function_list *functionlist; +static critbit_tree cb_functions; pf_generic get_function(const char *name) { - function_list *fl = functionlist; - if (name == NULL) - return NULL; - while (fl && strcmp(fl->name, name) != 0) - fl = fl->next; - if (fl) - return fl->fun; + const void * matches; + pf_generic result; + if (cb_find_prefix(&cb_functions, name, strlen(name)+1, &matches, 1, 0)) { + cb_get_kv(matches, &result, sizeof(result)); + return result; + } return NULL; } void register_function(pf_generic fun, const char *name) { - function_list *fl = (function_list *) malloc(sizeof(function_list)); - fl->next = functionlist; - fl->fun = fun; - fl->name = strdup(name); - functionlist = fl; + char buffer[64]; + size_t len = strlen(name); + + assert(len