Browse Source

#52491 Cosmetic: fix type cast and add comment with the algorithm source

Kirill Diduk 4 years ago
parent
commit
1f38b00242
1 changed files with 8 additions and 1 deletions
  1. 8 1
      core/templates/hashfuncs.h

+ 8 - 1
core/templates/hashfuncs.h

@@ -74,6 +74,13 @@ static inline uint32_t hash_djb2_one_32(uint32_t p_in, uint32_t p_prev = 5381) {
 	return ((p_prev << 5) + p_prev) + p_in;
 	return ((p_prev << 5) + p_prev) + p_in;
 }
 }
 
 
+/**
+ * Thomas Wang's 64-bit to 32-bit Hash function:
+ * https://web.archive.org/web/20071223173210/https:/www.concentric.net/~Ttwang/tech/inthash.htm
+ *
+ * @param p_int - 64-bit unsigned integer key to be hashed
+ * @return unsigned 32-bit value representing hashcode
+ */
 static inline uint32_t hash_one_uint64(const uint64_t p_int) {
 static inline uint32_t hash_one_uint64(const uint64_t p_int) {
 	uint64_t v = p_int;
 	uint64_t v = p_int;
 	v = (~v) + (v << 18); // v = (v << 18) - v - 1;
 	v = (~v) + (v << 18); // v = (v << 18) - v - 1;
@@ -82,7 +89,7 @@ static inline uint32_t hash_one_uint64(const uint64_t p_int) {
 	v = v ^ (v >> 11);
 	v = v ^ (v >> 11);
 	v = v + (v << 6);
 	v = v + (v << 6);
 	v = v ^ (v >> 22);
 	v = v ^ (v >> 22);
-	return (int)v;
+	return uint32_t(v);
 }
 }
 
 
 static inline uint32_t hash_djb2_one_float(double p_in, uint32_t p_prev = 5381) {
 static inline uint32_t hash_djb2_one_float(double p_in, uint32_t p_prev = 5381) {