diff options
author | Igor Sysoev <igor@sysoev.ru> | 2017-01-17 20:00:00 +0300 |
---|---|---|
committer | Igor Sysoev <igor@sysoev.ru> | 2017-01-17 20:00:00 +0300 |
commit | 16cbf3c076a0aca6d47adaf3f719493674cf2363 (patch) | |
tree | e6530480020f62a2bdbf249988ec3e2a751d3927 /src/nxt_djb_hash.h | |
download | unit-16cbf3c076a0aca6d47adaf3f719493674cf2363.tar.gz unit-16cbf3c076a0aca6d47adaf3f719493674cf2363.tar.bz2 |
Initial version.
Diffstat (limited to 'src/nxt_djb_hash.h')
-rw-r--r-- | src/nxt_djb_hash.h | 26 |
1 files changed, 26 insertions, 0 deletions
diff --git a/src/nxt_djb_hash.h b/src/nxt_djb_hash.h new file mode 100644 index 00000000..c7ba6fdb --- /dev/null +++ b/src/nxt_djb_hash.h @@ -0,0 +1,26 @@ + +/* + * Copyright (C) Igor Sysoev + * Copyright (C) NGINX, Inc. + */ + +#ifndef _NXT_DJB_HASH_H_INCLUDED_ +#define _NXT_DJB_HASH_H_INCLUDED_ + + +/* A fast and simple hash function by Daniel J. Bernstein. */ + + +NXT_EXPORT uint32_t nxt_djb_hash(const void *data, size_t len); +NXT_EXPORT uint32_t nxt_djb_hash_lowcase(const void *data, size_t len); + + +#define NXT_DJB_HASH_INIT 5381 + + +#define \ +nxt_djb_hash_add(hash, val) \ + ((uint32_t) ((((hash) << 5) + (hash)) ^ (uint32_t) (val))) + + +#endif /* _NXT_DJB_HASH_H_INCLUDED_ */ |