placed basic hash macros in qse/hash.h
This commit is contained in:
		| @ -31,6 +31,7 @@ | ||||
| /// Privides the Hashable interface class. | ||||
|  | ||||
| #include <qse/Types.hpp> | ||||
| #include <qse/hash.h> | ||||
|  | ||||
| ///////////////////////////////// | ||||
| QSE_BEGIN_NAMESPACE(QSE) | ||||
| @ -51,13 +52,7 @@ public: | ||||
| 	static qse_size_t getHashCode (qse_size_t init, const qse_mchar_t* str) | ||||
| 	{ | ||||
| 		qse_size_t n = init; | ||||
|  | ||||
| 		while (*str != QSE_MT('\0')) | ||||
| 		{ | ||||
| 			n = n * 31 + *((qse_uint8_t*)str); | ||||
| 			str++; | ||||
| 		} | ||||
|  | ||||
| 		QSE_HASH_MORE_MBS(n, str); | ||||
| 		return n; | ||||
| 	} | ||||
|  | ||||
| @ -69,15 +64,7 @@ public: | ||||
| 	static qse_size_t getHashCode (qse_size_t init, const qse_wchar_t* str) | ||||
| 	{ | ||||
| 		qse_size_t n = init; | ||||
|  | ||||
| 		while (*str != QSE_WT('\0')) | ||||
| 		{ | ||||
| 			const qse_uint8_t* p = (const qse_uint8_t*)str; | ||||
| 			for (qse_size_t i = 0; i < QSE_SIZEOF(*str); i++) | ||||
| 				n = n * 31 + *p++; | ||||
| 			str++; | ||||
| 		} | ||||
|  | ||||
| 		QSE_HASH_MORE_WCS(n, str); | ||||
| 		return n; | ||||
| 	} | ||||
|  | ||||
| @ -89,26 +76,7 @@ public: | ||||
| 	static qse_size_t getHashCode (qse_size_t init, const void* data, qse_size_t size) | ||||
| 	{ | ||||
| 		qse_size_t n = init; | ||||
| 		const qse_uint8_t* p = (const qse_uint8_t*)data; | ||||
|  | ||||
| 		/* | ||||
| 		for (qse_size_t i = 0; i < size; i++) { | ||||
| 			n <<= 1; | ||||
| 			n += *p++; | ||||
| 		} | ||||
| 		*/ | ||||
|  | ||||
| 		for (qse_size_t i = 0; i < size; i++) n = n * 31 + *p++; | ||||
|  | ||||
| 		/* | ||||
| 		for (qse_size_t i = 0; i < size; i++) { | ||||
| 			n = (n << 4) + *p++; | ||||
| 			//qse_size_t g = n & 0xF0000000U; | ||||
| 			qse_size_t g = n & ((qse_size_t)0xF << (qse_sizeof(qse_size_t) * 8 - 4)); | ||||
| 			n &= ~g; | ||||
| 		} | ||||
| 		*/ | ||||
|  | ||||
| 		QSE_HASH_BYTES (n, data, size); | ||||
| 		return n; | ||||
| 	} | ||||
|  | ||||
|  | ||||
							
								
								
									
										112
									
								
								qse/include/qse/hash.h
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										112
									
								
								qse/include/qse/hash.h
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,112 @@ | ||||
| /* | ||||
|  * $Id: types.h 560 2011-09-06 14:18:36Z hyunghwan.chung $ | ||||
|  * | ||||
|     Copyright (c) 2006-2014 Chung, Hyung-Hwan. All rights reserved. | ||||
|  | ||||
|     Redistribution and use in source and binary forms, with or without | ||||
|     modification, are permitted provided that the following conditions | ||||
|     are met: | ||||
|     1. Redistributions of source code must retain the above copyright | ||||
|        notice, this list of conditions and the following disclaimer. | ||||
|     2. Redistributions in binary form must reproduce the above copyright | ||||
|        notice, this list of conditions and the following disclaimer in the | ||||
|        documentation and/or other materials provided with the distribution. | ||||
|  | ||||
|     THIS SOFTWARE IS PROVIDED BY THE AUTHOR "AS IS" AND ANY EXPRESS OR | ||||
|     IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES | ||||
|     OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. | ||||
|     IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT, | ||||
|     INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT | ||||
|     NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, | ||||
|     DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY | ||||
|     THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT | ||||
|     (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF | ||||
|     THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
|  */ | ||||
|  | ||||
| #ifndef _QSE_HASH_H_ | ||||
| #define _QSE_HASH_H_ | ||||
|  | ||||
| #include <qse/types.h> | ||||
| #include <qse/macros.h> | ||||
|  | ||||
| #if MOO_SIZEOF_SIZE_T == 4 | ||||
| #	define QSE_HASH_FNV_MAGIC_INIT (0x811c9dc5) | ||||
| #	define QSE_HASH_FNV_MAGIC_PRIME (0x01000193) | ||||
| #elif MOO_SIZEOF_SIZE_T == 8 | ||||
| #	define QSE_HASH_FNV_MAGIC_INIT (0xCBF29CE484222325) | ||||
| #	define QSE_HASH_FNV_MAGIC_PRIME (0x100000001B3) | ||||
| #elif MOO_SIZEOF_SIZE_T == 16 | ||||
| #	define QSE_HASH_FNV_MAGIC_INIT (0x6C62272E07BB014262B821756295C58D) | ||||
| #	define QSE_HASH_FNV_MAGIC_PRIME (0x1000000000000000000013B) | ||||
| #endif | ||||
|  | ||||
| #if defined(QSE_HASH_FNV_MAGIC_INIT) | ||||
| 	/* FNV-1 hash */ | ||||
| #	define QSE_HASH_VALUE(hv,v) (((hv) ^ (v)) * QSE_HASH_FNV_MAGIC_PRIME) | ||||
|  | ||||
| #	define QSE_HASH_VALUES(hv, ptr, len, type) do { \ | ||||
| 		hv = QSE_HASH_FNV_MAGIC_INIT; \ | ||||
| 		QSE_HASH_MORE_VALUES (hv, ptr, len, type); \ | ||||
| 	} while(0) | ||||
|  | ||||
| #	define QSE_HASH_MORE_VALUES(hv, ptr, len, type) do { \ | ||||
| 		type* p = (type*)(ptr); \ | ||||
| 		type* q = (type*)p + (len); \ | ||||
| 		while (p < q) { hv = QSE_HASH_VALUE(hv, *p); p++; } \ | ||||
| 	} while(0) | ||||
|  | ||||
| #	define QSE_HASH_VS(hv, ptr, type) do { \ | ||||
| 		hv = QSE_HASH_FNV_MAGIC_INIT; \ | ||||
| 		QSE_HASH_MORE_VALUES (hv, ptr, type); \ | ||||
| 	} while(0) | ||||
|  | ||||
| #	define QSE_HASH_MORE_VS(hv, ptr, type) do { \ | ||||
| 		type* p = (type*)(ptr); \ | ||||
| 		while (*p) { hv = QSE_HASH_VALUE(hv, *p); p++; } \ | ||||
| 	} while(0) | ||||
|  | ||||
| #else | ||||
| 	/* SDBM hash */ | ||||
| #	define QSE_HASH_VALUE(hv,v) (((hv) << 6) + ((hv) << 16) - (hv) + (v)) | ||||
|  | ||||
| #	define QSE_HASH_VALUES(hv, ptr, len, type) do { \ | ||||
| 		hv = 0; \ | ||||
| 		QSE_HASH_MORE_VALUES (hv, ptr, len, type); \ | ||||
| 	} while(0) | ||||
|  | ||||
| #	define QSE_HASH_MORE_VALUES(hv, ptr, len, type) do { \ | ||||
| 		type* p = (type*)(ptr); \ | ||||
| 		type* q = (type*)p + (len); \ | ||||
| 		while (p < q) { hv = QSE_HASH_VALUE(hv, *p); p++; } \ | ||||
| 	} while(0) | ||||
|  | ||||
| #	define QSE_HASH_VS(hv, ptr, type) do { \ | ||||
| 		hv = 0; \ | ||||
| 		QSE_HASH_MORE_VS (hv, ptr, type); \ | ||||
| 	} while(0) | ||||
|  | ||||
| #	define QSE_HASH_MORE_VS(hv, ptr, type) do { \ | ||||
| 		type* p = (type*)(ptr); \ | ||||
| 		while (*p) { hv = QSE_HASH_VALUE(hv, *p); p++; } \ | ||||
| 	} while(0) | ||||
|  | ||||
| #endif | ||||
|  | ||||
| #define QSE_HASH_BYTES(hv, ptr, len) QSE_HASH_VALUES(hv, ptr, len, const qse_uint8_t) | ||||
| #define QSE_HASH_MORE_BYTES(hv, ptr, len) QSE_HASH_MORE_VALUES(hv, ptr, len, const qse_uint8_t) | ||||
|  | ||||
| #define QSE_HASH_MCHARS(hv, ptr, len) QSE_HASH_VALUES(hv, ptr, len, const qse_mchar_t) | ||||
| #define QSE_HASH_MORE_MCHARS(hv, ptr, len) QSE_HASH_MORE_VALUES(hv, ptr, len, const qse_mchar_t) | ||||
|  | ||||
| #define QSE_HASH_WCHARS(hv, ptr, len) QSE_HASH_VALUES(hv, ptr, len, const qse_wchar_t) | ||||
| #define QSE_HASH_MORE_WCHARS(hv, ptr, len) QSE_HASH_MORE_VALUES(hv, ptr, len, const qse_wchar_t) | ||||
|  | ||||
| #define QSE_HASH_MBS(hv, ptr) QSE_HASH_VS(hv, ptr, const qse_mchar_t) | ||||
| #define QSE_HASH_MORE_MBS(hv, ptr) QSE_HASH_MORE_VS(hv, ptr, const qse_mchar_t) | ||||
|  | ||||
| #define QSE_HASH_WCS(hv, ptr) QSE_HASH_VS(hv, ptr, const qse_wchar_t) | ||||
| #define QSE_HASH_MORE_WCS(hv, ptr) QSE_HASH_MORE_VS(hv, ptr, const qse_wchar_t) | ||||
|  | ||||
| #endif | ||||
|  | ||||
| @ -26,6 +26,7 @@ | ||||
|  | ||||
| #include "awk-prv.h" | ||||
| #include <qse/cmn/mbwc.h> | ||||
| #include <qse/hash.h> | ||||
|  | ||||
| #ifdef DEBUG_VAL | ||||
| #include <qse/cmn/sio.h> | ||||
| @ -1696,17 +1697,10 @@ int qse_awk_rtx_strtonum ( | ||||
| 	return 0; /* int */ | ||||
| } | ||||
|  | ||||
| static qse_awk_uint_t hash (qse_uint8_t* ptr, qse_size_t len) | ||||
| static QSE_INLINE qse_awk_uint_t hash (qse_uint8_t* ptr, qse_size_t len) | ||||
| { | ||||
| 	/* | ||||
| 	qse_awk_uint_t h = 5381; | ||||
| 	while (len > 0) h = ((h << 5) + h) + ptr[--len]; | ||||
| 	return h; | ||||
| 	*/ | ||||
|  | ||||
| 	/* SDBM hash */ | ||||
| 	qse_awk_uint_t h = 0; | ||||
| 	while (len > 0) h = (h << 6) + (h << 16) - h + ptr[--len]; | ||||
| 	qse_awk_uint_t h; | ||||
| 	QSE_HASH_BYTES (h, ptr, len); | ||||
| 	return h; | ||||
| } | ||||
|  | ||||
|  | ||||
| @ -25,6 +25,7 @@ | ||||
|  */ | ||||
|  | ||||
| #include <qse/cmn/htb.h> | ||||
| #include <qse/hash.h> | ||||
| #include "mem-prv.h" | ||||
|  | ||||
|  | ||||
| @ -735,25 +736,8 @@ pair_t* qse_htb_getnextpair (htb_t* htb, pair_t* pair, size_t* buckno) | ||||
|  | ||||
| size_t qse_htb_dflhash (const htb_t* htb, const void* kptr, size_t klen) | ||||
| { | ||||
| 	const byte_t* p = (const byte_t*)kptr; | ||||
| 	const byte_t* bound = p + klen; | ||||
| #if 0 | ||||
| 	/*size_t h = 2166136261;*/ | ||||
| 	/*size_t h = 0;*/ | ||||
| 	size_t h = 5381; | ||||
|  | ||||
| 	while (p < bound) | ||||
| 	{ | ||||
| 		/*h = (h * 16777619) ^ *p++;*/ | ||||
| 		/*h = h * 31 + *p++;*/ | ||||
| 		h = ((h << 5) + h) + *p++; | ||||
| 	} | ||||
| #else | ||||
| 	/* SDBM hash */ | ||||
| 	size_t h = 0; | ||||
| 	while (p < bound) h = (h << 6) + (h << 16) - h + *p++; | ||||
| #endif | ||||
|  | ||||
| 	size_t h; | ||||
| 	QSE_HASH_BYTES (h, kptr, klen); | ||||
| 	return h ;  | ||||
| } | ||||
|  | ||||
|  | ||||
| @ -1,4 +1,5 @@ | ||||
| #include <qse/cmn/oht.h> | ||||
| #include <qse/hash.h> | ||||
| #include "mem-prv.h" | ||||
|  | ||||
| #define DATA_PTR(oht,index) \ | ||||
| @ -6,19 +7,8 @@ | ||||
|  | ||||
| static QSE_INLINE_ALWAYS qse_size_t default_hasher (qse_oht_t* oht, const void* data) | ||||
| { | ||||
| 	const qse_byte_t* p = (const qse_byte_t*)data; | ||||
| 	const qse_byte_t* bound = p + oht->scale; | ||||
|  | ||||
| #if 0 | ||||
| 	// DJB2 hash | ||||
| 	qse_size_t h = 5381; | ||||
| 	while (p < bound) h = ((h << 5) + h) + *p++; | ||||
| #else | ||||
| 	// SDBM hash | ||||
| 	qse_size_t h = 0; | ||||
| 	while (p < bound) h = (h << 6) + (h << 16) - h + *p++; | ||||
| #endif | ||||
|  | ||||
| 	qse_size_t h; | ||||
| 	QSE_HASH_BYTES (h, data, oht->scale); | ||||
| 	return h ;  | ||||
| } | ||||
|  | ||||
|  | ||||
| @ -254,7 +254,6 @@ static qse_uint32_t dict_attr_value_hash (qse_htl_t* htl, const void* data) | ||||
| { | ||||
| 	const qse_raddic_attr_t* v = (const qse_raddic_attr_t*)data; | ||||
| 	qse_uint32_t hv; | ||||
|  | ||||
| 	hv = qse_genhash32(&v->vendor, QSE_SIZEOF(v->vendor)); | ||||
| 	return qse_genhash32_update(&v->attr, QSE_SIZEOF(v->attr), hv); | ||||
| } | ||||
|  | ||||
		Reference in New Issue
	
	Block a user