OLD | NEW |
1 /* | 1 /* |
2 * Copyright (C) 2005, 2006, 2008 Apple Inc. All rights reserved. | 2 * Copyright (C) 2005, 2006, 2008 Apple Inc. All rights reserved. |
3 * | 3 * |
4 * This library is free software; you can redistribute it and/or | 4 * This library is free software; you can redistribute it and/or |
5 * modify it under the terms of the GNU Library General Public | 5 * modify it under the terms of the GNU Library General Public |
6 * License as published by the Free Software Foundation; either | 6 * License as published by the Free Software Foundation; either |
7 * version 2 of the License, or (at your option) any later version. | 7 * version 2 of the License, or (at your option) any later version. |
8 * | 8 * |
9 * This library is distributed in the hope that it will be useful, | 9 * This library is distributed in the hope that it will be useful, |
10 * but WITHOUT ANY WARRANTY; without even the implied warranty of | 10 * but WITHOUT ANY WARRANTY; without even the implied warranty of |
(...skipping 14 matching lines...) Expand all Loading... |
25 #include <stdint.h> | 25 #include <stdint.h> |
26 | 26 |
27 namespace WTF { | 27 namespace WTF { |
28 | 28 |
29 template<size_t size> struct IntTypes; | 29 template<size_t size> struct IntTypes; |
30 template<> struct IntTypes<1> { typedef int8_t SignedType; typedef uint8_t U
nsignedType; }; | 30 template<> struct IntTypes<1> { typedef int8_t SignedType; typedef uint8_t U
nsignedType; }; |
31 template<> struct IntTypes<2> { typedef int16_t SignedType; typedef uint16_t
UnsignedType; }; | 31 template<> struct IntTypes<2> { typedef int16_t SignedType; typedef uint16_t
UnsignedType; }; |
32 template<> struct IntTypes<4> { typedef int32_t SignedType; typedef uint32_t
UnsignedType; }; | 32 template<> struct IntTypes<4> { typedef int32_t SignedType; typedef uint32_t
UnsignedType; }; |
33 template<> struct IntTypes<8> { typedef int64_t SignedType; typedef uint64_t
UnsignedType; }; | 33 template<> struct IntTypes<8> { typedef int64_t SignedType; typedef uint64_t
UnsignedType; }; |
34 | 34 |
35 // integer hash function | |
36 | |
37 // Thomas Wang's 32 Bit Mix Function: http://www.cris.com/~Ttwang/tech/intha
sh.htm | |
38 inline unsigned intHash(uint8_t key8) | 35 inline unsigned intHash(uint8_t key8) |
39 { | 36 { |
40 unsigned key = key8; | 37 return key8; |
41 key += ~(key << 15); | |
42 key ^= (key >> 10); | |
43 key += (key << 3); | |
44 key ^= (key >> 6); | |
45 key += ~(key << 11); | |
46 key ^= (key >> 16); | |
47 return key; | |
48 } | 38 } |
49 | 39 |
50 // Thomas Wang's 32 Bit Mix Function: http://www.cris.com/~Ttwang/tech/intha
sh.htm | |
51 inline unsigned intHash(uint16_t key16) | 40 inline unsigned intHash(uint16_t key16) |
52 { | 41 { |
53 unsigned key = key16; | 42 return key16; |
54 key += ~(key << 15); | |
55 key ^= (key >> 10); | |
56 key += (key << 3); | |
57 key ^= (key >> 6); | |
58 key += ~(key << 11); | |
59 key ^= (key >> 16); | |
60 return key; | |
61 } | 43 } |
62 | 44 |
63 // Thomas Wang's 32 Bit Mix Function: http://www.cris.com/~Ttwang/tech/intha
sh.htm | |
64 inline unsigned intHash(uint32_t key) | 45 inline unsigned intHash(uint32_t key) |
65 { | 46 { |
66 key += ~(key << 15); | 47 return key ^ (key >> 16); |
67 key ^= (key >> 10); | |
68 key += (key << 3); | |
69 key ^= (key >> 6); | |
70 key += ~(key << 11); | |
71 key ^= (key >> 16); | |
72 return key; | |
73 } | 48 } |
74 | 49 |
75 // Thomas Wang's 64 bit Mix Function: http://www.cris.com/~Ttwang/tech/intha
sh.htm | |
76 inline unsigned intHash(uint64_t key) | 50 inline unsigned intHash(uint64_t key) |
77 { | 51 { |
78 key += ~(key << 32); | 52 key ^= key >> 32; |
79 key ^= (key >> 22); | 53 key ^= key >> 16; |
80 key += ~(key << 13); | |
81 key ^= (key >> 8); | |
82 key += (key << 3); | |
83 key ^= (key >> 15); | |
84 key += ~(key << 27); | |
85 key ^= (key >> 31); | |
86 return static_cast<unsigned>(key); | 54 return static_cast<unsigned>(key); |
87 } | 55 } |
88 | 56 |
89 // Compound integer hash method: http://opendatastructures.org/versions/edit
ion-0.1d/ods-java/node33.html#SECTION00832000000000000000 | 57 // Compound integer hash method: http://opendatastructures.org/versions/edit
ion-0.1d/ods-java/node33.html#SECTION00832000000000000000 |
90 inline unsigned pairIntHash(unsigned key1, unsigned key2) | 58 inline unsigned pairIntHash(unsigned key1, unsigned key2) |
91 { | 59 { |
92 unsigned shortRandom1 = 277951225; // A random 32-bit value. | 60 unsigned shortRandom1 = 277951225; // A random 32-bit value. |
93 unsigned shortRandom2 = 95187966; // A random 32-bit value. | 61 unsigned shortRandom2 = 95187966; // A random 32-bit value. |
94 uint64_t longRandom = 19248658165952622LL; // A random 64-bit value. | 62 uint64_t longRandom = 19248658165952622LL; // A random 64-bit value. |
95 | 63 |
(...skipping 23 matching lines...) Expand all Loading... |
119 | 87 |
120 // pointer identity hash function | 88 // pointer identity hash function |
121 | 89 |
122 template<typename T> struct PtrHash { | 90 template<typename T> struct PtrHash { |
123 static unsigned hash(T key) | 91 static unsigned hash(T key) |
124 { | 92 { |
125 #if COMPILER(MSVC) | 93 #if COMPILER(MSVC) |
126 #pragma warning(push) | 94 #pragma warning(push) |
127 #pragma warning(disable: 4244) // work around what seems to be a bug in MSVC's c
onversion warnings | 95 #pragma warning(disable: 4244) // work around what seems to be a bug in MSVC's c
onversion warnings |
128 #endif | 96 #endif |
129 return IntHash<uintptr_t>::hash(reinterpret_cast<uintptr_t>(key)); | 97 uintptr_t keyIntPtr = reinterpret_cast<uintptr_t>(key); |
| 98 keyIntPtr ^= keyIntPtr >> 6; |
| 99 return IntHash<uintptr_t>::hash(keyIntPtr); |
130 #if COMPILER(MSVC) | 100 #if COMPILER(MSVC) |
131 #pragma warning(pop) | 101 #pragma warning(pop) |
132 #endif | 102 #endif |
133 } | 103 } |
134 static bool equal(T a, T b) { return a == b; } | 104 static bool equal(T a, T b) { return a == b; } |
135 static const bool safeToCompareToEmptyOrDeleted = true; | 105 static const bool safeToCompareToEmptyOrDeleted = true; |
136 }; | 106 }; |
137 template<typename P> struct PtrHash<RefPtr<P> > : PtrHash<P*> { | 107 template<typename P> struct PtrHash<RefPtr<P> > : PtrHash<P*> { |
138 using PtrHash<P*>::hash; | 108 using PtrHash<P*>::hash; |
139 static unsigned hash(const RefPtr<P>& key) { return hash(key.get()); } | 109 static unsigned hash(const RefPtr<P>& key) { return hash(key.get()); } |
(...skipping 72 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
212 | 182 |
213 template<typename T, typename U> struct DefaultHash<std::pair<T, U> > { type
def PairHash<T, U> Hash; }; | 183 template<typename T, typename U> struct DefaultHash<std::pair<T, U> > { type
def PairHash<T, U> Hash; }; |
214 | 184 |
215 } // namespace WTF | 185 } // namespace WTF |
216 | 186 |
217 using WTF::DefaultHash; | 187 using WTF::DefaultHash; |
218 using WTF::IntHash; | 188 using WTF::IntHash; |
219 using WTF::PtrHash; | 189 using WTF::PtrHash; |
220 | 190 |
221 #endif // WTF_HashFunctions_h | 191 #endif // WTF_HashFunctions_h |
OLD | NEW |