-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathctrie.h
70 lines (60 loc) · 2.36 KB
/
ctrie.h
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
/**
* Copyright (c) 2019, Clemens Lang <[email protected]>
* All rights reserved.
*
* Redistribution and use in source and binary forms, with or without
* modification, are permitted provided that the following conditions are met:
*
* 1. Redistributions of source code must retain the above copyright notice,
* this list of conditions and the following disclaimer.
*
* 2. Redistributions in binary form must reproduce the above copyright notice,
* this list of conditions and the following disclaimer in the documentation
* and/or other materials provided with the distribution.
*
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
* AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
* IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
* ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE
* LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
* CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
* SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
* INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
* CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
* ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
* POSSIBILITY OF SUCH DAMAGE.
*
* SPDX-License-Identifier: BSD-2-Clause
*/
#ifndef __CTRIE_H__
#define __CTRIE_H__
#include <stdint.h>
#if defined(USE_SHARED_MEMORY)
#include <shmalloc.h>
#define PTR(type) size_t
#define DEREF(ptr, output_type) (*((output_type*) (((char*) shm_base()) + ptr)))
#else /* defined(USE_SHARED_MEMORY) */
#define PTR(type) type*
#define DEREF(ptr, output_type) (*((output_type*) ptr))
#endif /* defined(USE_SHARED_MEMORY) */
typedef struct ctrie ctrie_t;
typedef enum {
LOOKUP_NOTFOUND = 0,
LOOKUP_FOUND = 1,
LOOKUP_BUG = 0xff
} lookup_result_t;
typedef enum {
INSERT_SUCCESS = 0,
INSERT_OUT_OF_MEMORY = 1,
INSERT_CAS_FAILED = 2,
INSERT_BUG = 0xff
} insert_result_t;
typedef struct {
uint32_t counter;
uint32_t flags;
} value_t;
lookup_result_t ctrie_lookup(PTR(ctrie_t) ctrie, const char* key, value_t* value);
insert_result_t ctrie_insert(PTR(ctrie_t) ctrie, const char* key, const value_t* value);
void ctrie_print(PTR(ctrie_t) ctrie);
PTR(ctrie_t) ctrie_new();
#endif /* defined(__CTRIE_H__) */