Depsgraph: New dependency graph integration commit
[blender.git] / source / blender / depsgraph / util / depsgraph_util_hash.h
1 /*
2  * ***** BEGIN GPL LICENSE BLOCK *****
3  *
4  * This program is free software; you can redistribute it and/or
5  * modify it under the terms of the GNU General Public License
6  * as published by the Free Software Foundation; either version 2
7  * of the License, or (at your option) any later version.
8  *
9  * This program is distributed in the hope that it will be useful,
10  * but WITHOUT ANY WARRANTY; without even the implied warranty of
11  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
12  * GNU General Public License for more details.
13  *
14  * You should have received a copy of the GNU General Public License
15  * along with this program; if not, write to the Free Software Foundation,
16  * Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
17  *
18  * The Original Code is Copyright (C) 2014 Blender Foundation.
19  * All rights reserved.
20  *
21  * Original Author: Brecht van Lommel
22  * Contributor(s): Lukas Toenne
23  */
24
25 #ifndef __DEPSGRAPH_UTIL_HASH_H__
26 #define __DEPSGRAPH_UTIL_HASH_H__
27
28 #if defined(DEG_NO_UNORDERED_MAP)
29 #  define DEG_HASH_NAMESPACE_BEGIN
30 #  define DEG_HASH_NAMESPACE_END
31 #endif
32
33 #if defined(DEG_TR1_UNORDERED_MAP)
34 #  include <tr1/unordered_map>
35 #  define DEG_HASH_NAMESPACE_BEGIN namespace std { namespace tr1 {
36 #  define DEG_HASH_NAMESPACE_END } }
37 using std::tr1::hash;
38 #endif
39
40 #if defined(DEG_STD_UNORDERED_MAP)
41 #  include <unordered_map>
42 #  define DEG_HASH_NAMESPACE_BEGIN namespace std {
43 #  define DEG_HASH_NAMESPACE_END }
44 using std::hash;
45 #endif
46
47 #if defined(DEG_STD_UNORDERED_MAP_IN_TR1_NAMESPACE)
48 #  include <unordered_map>
49 #  define DEG_HASH_NAMESPACE_BEGIN namespace std { namespace tr1 {
50 #  define DEG_HASH_NAMESPACE_END } }
51 using std::tr1::hash;
52 #endif
53
54 #if !defined(DEG_NO_UNORDERED_MAP) && !defined(DEG_TR1_UNORDERED_MAP) && \
55     !defined(DEG_STD_UNORDERED_MAP) && !defined(DEG_STD_UNORDERED_MAP_IN_TR1_NAMESPACE)  // NOLINT
56 #  error One of: DEG_NO_UNORDERED_MAP, DEG_TR1_UNORDERED_MAP,\
57  DEG_STD_UNORDERED_MAP, DEG_STD_UNORDERED_MAP_IN_TR1_NAMESPACE must be defined!  // NOLINT
58 #endif
59
60 /* XXX this might require 2 different variants for sizeof(size_t) (32 vs 64 bit) */
61 inline size_t hash_combine(size_t hash_a, size_t hash_b)
62 {
63         return hash_a ^ (hash_b + 0x9e3779b9 + (hash_a << 6) + (hash_a >> 2));
64 }
65
66 #endif  /* __DEPSGRAPH_UTIL_HASH_H__ */