/[LeafOK_CVS]/lbbs/include/trie_dict.h
ViewVC logotype

Contents of /lbbs/include/trie_dict.h

Parent Directory Parent Directory | Revision Log Revision Log


Revision 1.3 - (show annotations)
Sat May 17 02:41:19 2025 UTC (10 months ago) by sysadm
Branch: MAIN
Changes since 1.2: +1 -1 lines
Content type: text/x-chdr
Refine trie_dict to support all characters

1 /***************************************************************************
2 trie_dict.h - description
3 -------------------
4 Copyright : (C) 2004-2025 by Leaflet
5 Email : leaflet@leafok.com
6 ***************************************************************************/
7
8 /***************************************************************************
9 * *
10 * This program is free software; you can redistribute it and/or modify *
11 * it under the terms of the GNU General Public License as published by *
12 * the Free Software Foundation; either version 3 of the License, or *
13 * (at your option) any later version. *
14 * *
15 ***************************************************************************/
16
17 #ifndef _TRIE_DICT_H_
18 #define _TRIE_DICT_H_
19
20 #include <stdint.h>
21
22 #define TRIE_CHILDREN 256
23 #define TRIE_MAX_KEY_LEN 1023
24
25 struct trie_node_t
26 {
27 int64_t values[TRIE_CHILDREN];
28 int8_t flags[TRIE_CHILDREN];
29 struct trie_node_t *p_nodes[TRIE_CHILDREN];
30 };
31 typedef struct trie_node_t TRIE_NODE;
32
33 typedef void (*trie_dict_traverse_cb)(const char *, int64_t);
34
35 extern TRIE_NODE *trie_dict_create(void);
36 extern void trie_dict_destroy(TRIE_NODE *p_dict);
37
38 extern int trie_dict_set(TRIE_NODE *p_dict, const char *key, int64_t value);
39 extern int trie_dict_get(TRIE_NODE *p_dict, const char *key, int64_t *p_value);
40 extern int trie_dict_del(TRIE_NODE *p_dict, const char *key);
41
42 extern void trie_dict_traverse(TRIE_NODE *p_dict, trie_dict_traverse_cb cb);
43
44 #endif //_TRIE_DICT_H_

webmaster@leafok.com
ViewVC Help
Powered by ViewVC 1.3.0-beta1