Files
ModernCPP/detail/CP/CHash.hpp
2025-09-18 15:38:52 +08:00

135 lines
2.4 KiB
C++

#pragma once
#ifndef __FILE_Detail_CP_CHash_Hpp
#define __FILE_Detail_CP_CHash_Hpp
#ifndef FORCEINLINE
#define FORCEINLINE __forceinline
#endif // !FORCEINLINE
//
// Hash functions for common types.
//
FORCEINLINE uint32_t Hash(const uint8_t A)
{
return A;
}
FORCEINLINE uint32_t Hash(const int8_t A)
{
return A;
}
FORCEINLINE uint32_t Hash(const uint16_t A)
{
return A;
}
FORCEINLINE uint32_t Hash(const int16_t A)
{
return A;
}
FORCEINLINE uint32_t Hash(const int32_t A)
{
return A;
}
FORCEINLINE uint32_t Hash(const uint32_t A)
{
return A;
}
FORCEINLINE uint32_t Hash(const uint64_t A)
{
return (uint32_t)A + ((uint32_t)(A >> 32) * 23);
}
FORCEINLINE uint32_t Hash(const int64_t A)
{
return (uint32_t)A + ((uint32_t)(A >> 32) * 23);
}
uint32_t Hash(const char* str, uint32_t hash = 5381)
{
return *str == '\0' ? hash : Hash(str + 1, ((hash << 5) + hash) + *str);
}
template<typename StringView>
uint32_t Hash(StringView str, uint32_t hash = 5381)
{
for (size_t i = 0; i < str.length(); ++i)
{
hash = ((hash << 5) + hash) + str[i];
}
return hash;
}
uint32_t THash(const char* const object, unsigned int length, uint32_t hash = 5381)
{
return (length == 0) ? hash : THash(object + 1, length - 1, ((hash << 5) + hash) + *object);
}
template<typename T>
uint32_t THash(T* object, uint32_t hash = 5381)
{
return THash((char*)object, sizeof(T), hash);
}
FORCEINLINE constexpr uint32_t CHash(const uint8_t A)
{
return A;
}
FORCEINLINE constexpr uint32_t CHash(const int8_t A)
{
return A;
}
FORCEINLINE constexpr uint32_t CHash(const uint16_t A)
{
return A;
}
FORCEINLINE constexpr uint32_t CHash(const int16_t A)
{
return A;
}
FORCEINLINE constexpr uint32_t CHash(const int32_t A)
{
return A;
}
FORCEINLINE constexpr uint32_t CHash(const uint32_t A)
{
return A;
}
FORCEINLINE constexpr uint32_t CHash(const uint64_t A)
{
return (uint32_t)A + ((uint32_t)(A >> 32) * 23);
}
FORCEINLINE constexpr uint32_t CHash(const int64_t A)
{
return (uint32_t)A + ((uint32_t)(A >> 32) * 23);
}
constexpr uint32_t CHash(const char* str, uint32_t hash = 5381)
{
return *str == '\0' ? hash : CHash(str + 1, ((hash << 5) + hash) + *str);
}
template<typename StringView>
constexpr uint32_t CHash(StringView str, uint32_t hash = 5381)
{
for (size_t i = 0; i < str.length(); ++i)
{
hash = ((hash << 5) + hash) + str[i];
}
return hash;
}
#endif // !__FILE_Detail_CP_CHash_Hpp