forked from Bananymous/banan-os
				
			BAN: Add basic hashing functionality
This commit is contained in:
		
							parent
							
								
									4f8fcf0bd7
								
							
						
					
					
						commit
						7630df84ad
					
				|  | @ -0,0 +1,50 @@ | |||
| #pragma once | ||||
| 
 | ||||
| #include <BAN/Traits.h> | ||||
| #include <stddef.h> | ||||
| #include <stdint.h> | ||||
| 
 | ||||
| namespace BAN | ||||
| { | ||||
| 
 | ||||
| 	template<typename T> | ||||
| 	struct hash; | ||||
| 
 | ||||
| 	using hash_t = uint32_t; | ||||
| 
 | ||||
| 	inline constexpr hash_t u32_hash(uint32_t val) | ||||
| 	{ | ||||
| 		val = ((val >> 16) ^ val) * 0x119de1f3; | ||||
| 		val = ((val >> 16) ^ val) * 0x119de1f3; | ||||
| 		val = ((val >> 16) ^ val); | ||||
| 		return val; | ||||
| 	} | ||||
| 
 | ||||
| 	inline constexpr hash_t u64_hash(uint64_t val) | ||||
| 	{ | ||||
| 		hash_t low = u32_hash(val); | ||||
| 		hash_t high = u32_hash(val >> 32); | ||||
| 		return low ^ high; | ||||
| 	} | ||||
| 
 | ||||
| 	template<integral T> | ||||
| 	struct hash<T> | ||||
| 	{ | ||||
| 		constexpr hash_t operator()(T val) const | ||||
| 		{ | ||||
| 			if constexpr(sizeof(val) <= sizeof(uint32_t)) | ||||
| 				return u32_hash(val); | ||||
| 			return u64_hash(val); | ||||
| 		} | ||||
| 	}; | ||||
| 
 | ||||
| 	template<pointer T> | ||||
| 	struct hash<T> | ||||
| 	{ | ||||
| 		constexpr hash_t operator()(T val) const | ||||
| 		{ | ||||
| 			return hash<uintptr_t>()((uintptr_t)val); | ||||
| 		} | ||||
| 	}; | ||||
| 
 | ||||
| } | ||||
		Loading…
	
		Reference in New Issue