1 | /* |
2 | * This Source Code Form is subject to the terms of the Mozilla Public |
3 | * License, v. 2.0. If a copy of the MPL was not distributed with this |
4 | * file, You can obtain one at http://mozilla.org/MPL/2.0/. |
5 | * |
6 | * Copyright 1997 - July 2008 CWI, August 2008 - 2019 MonetDB B.V. |
7 | */ |
8 | |
9 | #ifndef SQL_HASH_H |
10 | #define SQL_HASH_H |
11 | |
12 | /* sql_hash implementation |
13 | * used to optimize search in expression and statement lists |
14 | */ |
15 | |
16 | #include "sql_mem.h" |
17 | |
18 | #define HASH_MIN_SIZE 4 |
19 | |
20 | typedef int (*fkeyvalue) (void *data); |
21 | |
22 | typedef struct sql_hash_e { |
23 | int key; |
24 | void *value; |
25 | struct sql_hash_e *chain; |
26 | } sql_hash_e; |
27 | |
28 | typedef struct sql_hash { |
29 | sql_allocator *sa; |
30 | int size; /* power of 2 */ |
31 | sql_hash_e **buckets; |
32 | fkeyvalue key; |
33 | } sql_hash; |
34 | |
35 | extern sql_hash *hash_new(sql_allocator *sa, int size, fkeyvalue key); |
36 | extern sql_hash_e *hash_add(sql_hash *ht, int key, void *value); |
37 | extern void hash_del(sql_hash *ht, int key, void *value); |
38 | |
39 | extern unsigned int hash_key(const char *n); |
40 | |
41 | #endif /* SQL_HASH_H */ |
42 | |