1 // VirtualDub - Video processing and capture application
2 // System library component
3 // Copyright (C) 1998-2007 Avery Lee, All Rights Reserved.
5 // Beginning with 1.6.0, the VirtualDub system library is licensed
6 // differently than the remainder of VirtualDub. This particular file is
7 // thus licensed as follows (the "zlib" license):
9 // This software is provided 'as-is', without any express or implied
10 // warranty. In no event will the authors be held liable for any
11 // damages arising from the use of this software.
13 // Permission is granted to anyone to use this software for any purpose,
14 // including commercial applications, and to alter it and redistribute it
15 // freely, subject to the following restrictions:
17 // 1. The origin of this software must not be misrepresented; you must
18 // not claim that you wrote the original software. If you use this
19 // software in a product, an acknowledgment in the product
20 // documentation would be appreciated but is not required.
21 // 2. Altered source versions must be plainly marked as such, and must
22 // not be misrepresented as being the original software.
23 // 3. This notice may not be removed or altered from any source
27 #include <vd2/system/hash.h>
28 #include <vd2/system/binary.h>
30 // Based on: SuperFastHash by Paul Hsieh
31 // http://www.azillionmonkeys.com/qed/hash.html
33 uint32
VDHashString32(const char *s
) {
34 uint32 len
= (uint32
)strlen(s
);
36 return VDHashString32(s
, len
);
39 uint32
VDHashString32(const char *s
, uint32 len
) {
46 for(uint32 i
=0; i
<len
; ++i
) {
47 hash
+= VDReadUnalignedU16(s
);
48 tmp
= (VDReadUnalignedU16(s
+ 2) << 11) ^ hash
;
49 hash
= (hash
<< 16) ^ tmp
;
56 hash
+= VDReadUnalignedU16(s
);
58 hash
^= (uint32
)(uint8
)s
[2] << 18;
62 hash
+= VDReadUnalignedU16(s
);
83 uint32
VDHashString32(const wchar_t *s
) {
84 return VDHashString32((const char *)s
, wcslen(s
) * sizeof(wchar_t));
87 uint32
VDHashString32(const wchar_t *s
, uint32 len
) {
88 return VDHashString32((const char *)s
, len
* sizeof(wchar_t));
91 uint32
VDHashString32I(const char *s
) {
92 uint32 len
= (uint32
)strlen(s
);
94 return VDHashString32I(s
, len
);
97 uint32
VDHashString32I(const char *s
, uint32 len
) {
98 uint32 hash
= 2166136261U;
100 for(uint32 i
=0; i
<len
; ++i
) {
102 hash
^= (uint32
)tolower((unsigned char)*s
++);
108 uint32
VDHashString32I(const wchar_t *s
) {
109 uint32 len
= (uint32
)wcslen(s
);
111 return VDHashString32I(s
, len
);
114 uint32
VDHashString32I(const wchar_t *s
, uint32 len
) {
115 uint32 hash
= 2166136261U;
117 for(uint32 i
=0; i
<len
; ++i
) {
119 hash
^= (uint32
)towlower(*s
++);