Cycles: Code cleanup, spaces around keywords
[blender-staging.git] / intern / cycles / util / util_hash.h
1 /*
2  * Copyright 2011-2013 Blender Foundation
3  *
4  * Licensed under the Apache License, Version 2.0 (the "License");
5  * you may not use this file except in compliance with the License.
6  * You may obtain a copy of the License at
7  *
8  * http://www.apache.org/licenses/LICENSE-2.0
9  *
10  * Unless required by applicable law or agreed to in writing, software
11  * distributed under the License is distributed on an "AS IS" BASIS,
12  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13  * See the License for the specific language governing permissions and
14  * limitations under the License.
15  */
16
17 #ifndef __UTIL_HASH_H__
18 #define __UTIL_HASH_H__
19
20 #include "util_types.h"
21
22 CCL_NAMESPACE_BEGIN
23
24 static inline uint hash_int_2d(uint kx, uint ky)
25 {
26 #define rot(x,k) (((x)<<(k)) | ((x)>>(32-(k))))
27
28         uint a, b, c;
29
30         a = b = c = 0xdeadbeef + (2 << 2) + 13;
31         a += kx;
32         b += ky;
33
34         c ^= b; c -= rot(b,14);
35         a ^= c; a -= rot(c,11);
36         b ^= a; b -= rot(a,25);
37         c ^= b; c -= rot(b,16);
38         a ^= c; a -= rot(c,4);
39         b ^= a; b -= rot(a,14);
40         c ^= b; c -= rot(b,24);
41
42         return c;
43
44 #undef rot
45 }
46
47 static inline uint hash_int(uint k)
48 {
49         return hash_int_2d(k, 0);
50 }
51
52 static inline uint hash_string(const char *str)
53 {
54         uint i = 0, c;
55
56         while((c = *str++))
57                 i = i * 37 + c;
58
59         return i;
60 }
61
62 CCL_NAMESPACE_END
63
64 #endif /* __UTIL_HASH_H__ */
65