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
|
/*
* $Id$
*
* Copyright (C) 2006 iptelorg GmbH
*
* Permission to use, copy, modify, and distribute this software for any
* purpose with or without fee is hereby granted, provided that the above
* copyright notice and this permission notice appear in all copies.
*
* THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
* WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
* MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
* ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
* WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
* ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
* OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
*/
/*
* History:
* --------
* 2006-02-02 created by andrei
* 2006-11-24 added numeric string optimized hash function (andrei)
* 2006-12-13 split into hashes.h (more generic) and str_hash.h (andrei)
*/
#ifndef _str_hashs_h
#define _str_hashs_h
#include "str.h"
#include "hashes.h"
#include "mem/mem.h"
#include "clist.h"
#include <string.h>
/* generic, simple str keyed hash */
struct str_hash_entry{
struct str_hash_entry* next;
struct str_hash_entry* prev;
str key;
unsigned int flags;
union{
void* p;
char* s;
int n;
char data[sizeof(void*)];
}u;
};
struct str_hash_head{
struct str_hash_entry* next;
struct str_hash_entry* prev;
};
struct str_hash_table{
struct str_hash_head* table;
int size;
};
/* returns 0 on success, <0 on failure */
inline static int str_hash_alloc(struct str_hash_table* ht, int size)
{
ht->table=(struct str_hash_head*)pkg_malloc(sizeof(struct str_hash_head)*size);
if (ht->table==0)
return -1;
ht->size=size;
return 0;
}
inline static void str_hash_init(struct str_hash_table* ht)
{
int r;
for (r=0; r<ht->size; r++) clist_init(&(ht->table[r]), next, prev);
}
inline static void str_hash_add(struct str_hash_table* ht,
struct str_hash_entry* e)
{
int h;
h=get_hash1_raw(e->key.s, e->key.len) % ht->size;
clist_insert(&ht->table[h], e, next, prev);
}
inline static struct str_hash_entry* str_hash_get(struct str_hash_table* ht,
const char* key, int len)
{
int h;
struct str_hash_entry* e;
h=get_hash1_raw(key, len) % ht->size;
clist_foreach(&ht->table[h], e, next){
if ((e->key.len==len) && (memcmp(e->key.s, key, len)==0))
return e;
}
return 0;
}
#define str_hash_del(e) clist_rm(e, next, prev)
#endif
|