Go to the documentation of this file.
35 HashTable*
HashTableInit(uint32_t size, uint32_t (*Hash)(
struct HashTable_ *,
void *, uint16_t),
char (*Compare)(
void *, uint16_t,
void *, uint16_t),
void (*Free)(
void *)) {
63 if (ht->
array == NULL)
70 if (ht->
array != NULL)
79 uint32_t (*Hash)(
struct HashTable_ *,
void *, uint16_t),
80 char (*Compare)(
void *, uint16_t,
void *, uint16_t),
void (*Free)(
void *),
102 return next_hashbucket;
118 for (uint32_t i = 0; i < ht->
array_size; i++) {
120 while (hashbucket != NULL) {
121 hashbucket = HashTableBucketFree(ht, hashbucket);
126 if (ht->
array != NULL)
134 if (ht == NULL || data == NULL)
137 uint32_t hash = ht->
Hash(ht, data, datalen);
147 SCLogWarning(
"attempt to insert element out of hash array\n");
151 if (ht->
array[hash] == NULL) {
152 ht->
array[hash] = hb;
155 ht->
array[hash] = hb;
180 uint32_t hash = ht->
Hash(ht, data, datalen);
183 while (*hashbucket != NULL) {
184 if (ht->
Compare((*hashbucket)->data, (*hashbucket)->size, data, datalen)) {
185 *hashbucket = HashTableBucketFree(ht, *hashbucket);
188 hashbucket = &((*hashbucket)->next);
201 hash = ht->
Hash(ht, data, datalen);
204 SCLogWarning(
"attempt to access element out of hash array\n");
208 if (ht->
array[hash] == NULL)
213 if (ht->
Compare(hashbucket->
data, hashbucket->
size, data, datalen) == 1)
214 return hashbucket->
data;
216 hashbucket = hashbucket->
next;
217 }
while (hashbucket != NULL);
225 if (ht == NULL || CallbackFn == NULL)
228 for (uint32_t i = 0; i < ht->
array_size; i++) {
230 while (hashbucket != NULL) {
231 CallbackFn(hashbucket->
data, aux);
232 hashbucket = hashbucket->
next;
239 uint8_t *d = (uint8_t *)data;
243 for (i = 0; i < datalen; i++) {
244 if (i == 0) hash += (((uint32_t)*d++));
245 else if (i == 1) hash += (((uint32_t)*d++) * datalen);
246 else hash *= (((uint32_t)*d++) * i) + datalen + i;
259 if (
SCMemcmp(data1,data2,len1) != 0)
270 static int HashTableTestInit01 (
void)
281 static int HashTableTestInit02 (
void)
291 static int HashTableTestInit03 (
void)
305 static int HashTableTestInit04 (
void)
315 static int HashTableTestInit05 (
void)
329 static char HashTableDefaultCompareTest(
void *data1, uint16_t len1,
void *data2, uint16_t len2)
334 if (
SCMemcmp(data1,data2,len1) != 0)
340 static int HashTableTestInit06 (
void)
347 if (ht->
Compare == HashTableDefaultCompareTest)
354 static int HashTableTestAdd01 (
void)
372 static int HashTableTestAdd02 (
void)
390 static int HashTableTestFull01 (
void)
416 static int HashTableTestFull02 (
void)
442 static int HashTableTestCollisionBug(
void)
491 UtRegisterTest(
"HashTableTestCollisionBug", HashTableTestCollisionBug);
#define FAIL_IF_NULL(expr)
Fail a test if expression evaluates to NULL.
char HashTableDefaultCompare(void *data1, uint16_t len1, void *data2, uint16_t len2)
void UtRegisterTest(const char *name, int(*TestFn)(void))
Register unit test.
void HashTableIterate(HashTable *ht, void(*CallbackFn)(void *, void *), void *aux)
#define FAIL_IF_NOT(expr)
Fail a test if expression evaluates to false.
void HashTableFree(HashTable *ht)
Free a HashTable and all its contents.
#define FAIL_IF_NOT_NULL(expr)
Fail a test if expression evaluates to non-NULL.
#define PASS
Pass the test.
HashTable * HashTableInitWithSeed(uint32_t size, uint32_t(*Hash)(struct HashTable_ *, void *, uint16_t), char(*Compare)(void *, uint16_t, void *, uint16_t), void(*Free)(void *), const uint32_t seed)
char(* Compare)(void *, uint16_t, void *, uint16_t)
void HashTableRegisterTests(void)
void * HashTableLookup(HashTable *ht, void *data, uint16_t datalen)
int HashTableRemove(HashTable *ht, void *data, uint16_t datalen)
Remove an item from the hash table.
#define SCLogWarning(...)
Macro used to log WARNING messages.
int HashTableAdd(HashTable *ht, void *data, uint16_t datalen)
struct HashTableBucket_ * next
#define FAIL_IF(expr)
Fail a test if expression evaluates to true.
HashTable * HashTableInit(uint32_t size, uint32_t(*Hash)(struct HashTable_ *, void *, uint16_t), char(*Compare)(void *, uint16_t, void *, uint16_t), void(*Free)(void *))
uint32_t HashTableGenericHash(HashTable *ht, void *data, uint16_t datalen)
#define SCMemcmp(a, b, c)
uint32_t(* Hash)(struct HashTable_ *, void *, uint16_t)