83 lines
2.4 KiB
C
Raw Normal View History

/*
* trie.h
*
* Copyright (C) 2014 Tobias Boege <tobias@gambas-buch.de>
*
* This program is free software; you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation; either version 2, or (at your option)
* any later version.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with this program; if not, write to the Free Software
* Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston,
* MA 02110-1301, USA.
*/
#ifndef TRIE_H
#define TRIE_H
#include <stddef.h>
#include <stdint.h>
struct trie {
uint64_t mask[4]; /* 256 Bits */
struct trie **children;
unsigned int nchildren;
void *value;
size_t len;
char key[];
};
enum trie_path {
TRIE_UNSET = 0, /* No chance to get a match from here */
TRIE_EXIST, /* We are within a key */
TRIE_EXACT, /* We got an exact match */
};
struct trie_prefix {
enum trie_path state;
struct trie *node;
int i;
};
extern struct trie *new_trie(void);
extern void destroy_trie(struct trie *trie, void (*dtor)(void *));
extern void clear_trie(struct trie *trie, void (*dtor)(void *));
extern void *trie_insert(struct trie *trie, const char *key, size_t len,
void *value);
extern void trie_remove(struct trie *trie, const char *key, size_t len,
void (*dtor)(void *));
extern struct trie *trie_find(const struct trie *trie, const char *key,
size_t len);
extern void *trie_value(const struct trie *trie, const char *key,
size_t len);
static inline void trie_reset_prefix(struct trie_prefix *p)
{
p->state = TRIE_UNSET;
p->node = NULL;
p->i = 0;
}
extern void trie_constrain(const struct trie *trie,
struct trie_prefix *p, char c);
extern void trie_constrain2(const struct trie *trie,
struct trie_prefix *p, const char *str,
size_t len);
extern struct trie *trie_find2(const struct trie *trie,
const struct trie_prefix *p,
const char *key, size_t len);
extern void *trie_value2(const struct trie *trie,
const struct trie_prefix *p,
const char *key, size_t len);
#endif /* TRIE_H */