Hash.h 2.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145
  1. #pragma once
  2. #include "../Common.h"
  3. #include "../FileStream.h"
  4. NS_BF_BEGIN
  5. class Val128
  6. {
  7. public:
  8. struct Hash
  9. {
  10. size_t operator()(const Val128& entry) const
  11. {
  12. return (size_t)(entry.mLow ^ entry.mHigh);
  13. }
  14. };
  15. struct Equals
  16. {
  17. bool operator()(const Val128& lhs, const Val128& rhs) const
  18. {
  19. return (lhs.mLow == rhs.mLow) && (lhs.mHigh == rhs.mHigh);
  20. }
  21. };
  22. public:
  23. uint64 mLow;
  24. uint64 mHigh;
  25. public:
  26. Val128()
  27. {
  28. mLow = 0;
  29. mHigh = 0;
  30. }
  31. Val128(int val)
  32. {
  33. mLow = (uint64)val;
  34. mHigh = 0;
  35. }
  36. Val128& operator=(int val)
  37. {
  38. mLow = (uint64)val;
  39. mHigh = 0;
  40. return *this;
  41. }
  42. bool IsZero()
  43. {
  44. return (mLow == 0) && (mHigh == 0);
  45. }
  46. explicit operator int()
  47. {
  48. return (int)mLow;
  49. }
  50. String ToString()
  51. {
  52. return StrFormat("%lX%lX", mHigh, mLow);
  53. }
  54. };
  55. static bool operator!=(const Val128& l, int rLow)
  56. {
  57. return (l.mHigh != 0) || (l.mLow != rLow);
  58. }
  59. static bool operator==(const Val128& l, const Val128& r)
  60. {
  61. return (l.mLow == r.mLow) && (l.mHigh == r.mHigh);
  62. }
  63. static bool operator!=(const Val128& l, const Val128& r)
  64. {
  65. return (l.mLow != r.mLow) || (l.mHigh != r.mHigh);
  66. }
  67. static bool operator<(const Val128& l, const Val128& r)
  68. {
  69. int* lPtr = (int*)&l.mLow;
  70. int* rPtr = (int*)&r.mLow;
  71. if (lPtr[3] != rPtr[3]) //-V557
  72. return lPtr[3] < rPtr[3]; //-V557
  73. if (lPtr[2] != rPtr[2]) //-V557
  74. return lPtr[2] < rPtr[2]; //-V557
  75. if (lPtr[1] != rPtr[1])
  76. return lPtr[1] < rPtr[1];
  77. return lPtr[0] < rPtr[0];
  78. }
  79. uint64 Hash64(uint64 hash, uint64 seed);
  80. uint64 Hash64(const void* data, int length, uint64 seed = 0);
  81. Val128 Hash128(const void* data, int length);
  82. Val128 Hash128(const void* data, int length, const Val128& seed);
  83. Val128 HashMD5(const void* data, int length);
  84. String HashEncode64(uint64 val); // Note: this only encodes the low 60 bits. Returns up to 10 characters.
  85. StringT<21> HashEncode128(Val128 val); // Returns up to 20 characters.
  86. #define HASH128_MIXIN(hashVal, data) hashVal = Hash128(&data, sizeof(data), hashVal)
  87. #define HASH128_MIXIN_PTR(hashVal, data, size) hashVal = Hash128(data, size, hashVal)
  88. #define HASH128_MIXIN_STR(hashVal, str) hashVal = Hash128(str.c_str(), (int)str.length(), hashVal)
  89. class HashContext
  90. {
  91. public:
  92. uint8 mBuf[1024];
  93. int mBufSize;
  94. int mBufOffset;
  95. #ifdef BF_PLATFORM_WINDOWS
  96. bool mDbgViz;
  97. FileStream* mDbgVizStream;
  98. #endif
  99. public:
  100. HashContext()
  101. {
  102. mBufOffset = 0;
  103. mBufSize = 0;
  104. #ifdef BF_PLATFORM_WINDOWS
  105. mDbgViz = false;
  106. mDbgVizStream = NULL;
  107. #endif
  108. }
  109. ~HashContext();
  110. void Reset();
  111. void Mixin(const void* data, int size);
  112. template <typename T>
  113. void Mixin(const T& val)
  114. {
  115. Mixin((void*)&val, (int)sizeof(val));
  116. }
  117. void MixinHashContext(HashContext& ctx);
  118. void MixinStr(const char* str);
  119. void MixinStr(const StringImpl& str);
  120. Val128 Finish128();
  121. uint64 Finish64();
  122. };
  123. NS_BF_END