2008-03-07 23:28:12 -08:00
|
|
|
/*
|
|
|
|
* vim:ts=8:sw=3:sts=8:noexpandtab:cino=>5n-3f0^-2{2
|
|
|
|
*/
|
|
|
|
|
2009-08-23 02:36:43 -07:00
|
|
|
#ifdef HAVE_CONFIG_H
|
|
|
|
# include <config.h>
|
|
|
|
#endif
|
|
|
|
|
2007-09-25 11:26:49 -07:00
|
|
|
#include <stdio.h>
|
|
|
|
#include <math.h>
|
|
|
|
|
2008-04-03 12:30:18 -07:00
|
|
|
#include "Eet.h"
|
|
|
|
#include "Eet_private.h"
|
|
|
|
|
2006-12-28 07:23:47 -08:00
|
|
|
int
|
|
|
|
_eet_hash_gen(const char *key, int hash_size)
|
|
|
|
{
|
|
|
|
int hash_num = 0;
|
|
|
|
int value, i;
|
2008-09-11 04:24:13 -07:00
|
|
|
int mask;
|
2006-12-28 07:23:47 -08:00
|
|
|
unsigned char *ptr;
|
2008-03-07 23:28:12 -08:00
|
|
|
|
2006-12-28 07:23:47 -08:00
|
|
|
/* no string - index 0 */
|
|
|
|
if (!key) return 0;
|
2008-03-07 23:28:12 -08:00
|
|
|
|
2006-12-28 07:23:47 -08:00
|
|
|
/* calc hash num */
|
|
|
|
for (i = 0, ptr = (unsigned char *)key, value = (int)(*ptr);
|
|
|
|
value;
|
|
|
|
ptr++, i++, value = (int)(*ptr))
|
|
|
|
hash_num ^= (value | (value << 8)) >> (i & 0x7);
|
|
|
|
|
|
|
|
/* mask it */
|
2008-09-11 04:24:13 -07:00
|
|
|
mask = (1 << hash_size) - 1;
|
|
|
|
hash_num &= mask;
|
2006-12-28 07:23:47 -08:00
|
|
|
/* return it */
|
|
|
|
return hash_num;
|
|
|
|
}
|
|
|
|
|