-
Notifications
You must be signed in to change notification settings - Fork 25
/
jwHash.h
executable file
·123 lines (98 loc) · 3.02 KB
/
jwHash.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
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
/*
Copyright 2015 Jonathan Watmough
Licensed under the Apache License, Version 2.0 (the "License");
you may not use this file except in compliance with the License.
You may obtain a copy of the License at
http://www.apache.org/licenses/LICENSE-2.0
Unless required by applicable law or agreed to in writing, software
distributed under the License is distributed on an "AS IS" BASIS,
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
See the License for the specific language governing permissions and
limitations under the License.
*/
//#define HASHTHREADED 1
//#define HASHTEST 1
//#define HASHDEBUG 1
// guards! guards!
#ifndef jwhash_h
#define jwhash_h
// needed for size_t
#include <stddef.h>
#ifdef HASHDEBUG
# define HASH_DEBUG(fmt,args...) printf(fmt, ## args)
#else
# define HASH_DEBUG(fmt,args...) do {} while (0);
#endif
// result codes
typedef enum
{
HASHOK,
HASHADDED,
HASHREPLACEDVALUE,
HASHALREADYADDED,
HASHDELETED,
HASHNOTFOUND,
} HASHRESULT;
typedef enum
{
HASHPTR,
HASHNUMERIC,
HASHSTRING,
} HASHVALTAG;
typedef struct jwHashEntry jwHashEntry;
struct jwHashEntry
{
union
{
char *strValue;
double dblValue;
int intValue;
} key;
HASHVALTAG valtag;
union
{
char *strValue;
double dblValue;
int intValue;
void *ptrValue;
} value;
jwHashEntry *next;
};
typedef struct jwHashTable jwHashTable;
struct jwHashTable
{
jwHashEntry **bucket; // pointer to array of buckets
size_t buckets;
size_t bucketsinitial; // if we resize, may need to hash multiple times
HASHRESULT lastError;
#ifdef HASHTHREADED
volatile int *locks; // array of locks
volatile int lock; // lock for entire table
#endif
};
// Create/delete hash table
jwHashTable *create_hash( size_t buckets );
void *delete_hash( jwHashTable *table ); // clean up all memory
// Add to table - keyed by string
HASHRESULT add_str_by_str( jwHashTable*, char *key, char *value );
HASHRESULT add_dbl_by_str( jwHashTable*, char *key, double value );
HASHRESULT add_int_by_str( jwHashTable*, char *key, long int value );
HASHRESULT add_ptr_by_str( jwHashTable*, char *key, void *value );
// Delete by string
HASHRESULT del_by_str( jwHashTable*, char *key );
// Get by string
HASHRESULT get_str_by_str( jwHashTable *table, char *key, char **value );
HASHRESULT get_int_by_str( jwHashTable *table, char *key, int *i );
HASHRESULT get_dbl_by_str( jwHashTable *table, char *key, double *val );
// Add to table - keyed by int
HASHRESULT add_str_by_int( jwHashTable*, long int key, char *value );
HASHRESULT add_dbl_by_int( jwHashTable*, long int key, double value );
HASHRESULT add_int_by_int( jwHashTable*, long int key, long int value );
HASHRESULT add_ptr_by_int( jwHashTable*, long int key, void *value );
// Delete by int
HASHRESULT del_by_int( jwHashTable*, long int key );
// Get by int
HASHRESULT get_str_by_int( jwHashTable *table, long int key, char **value );
HASHRESULT get_int_by_int( jwHashTable *table, long int key, int *i );
HASHRESULT get_dbl_by_int( jwHashTable *table, long int key, double *val );
#endif