Index: third_party/protobuf/m4/stl_hash.m4 |
diff --git a/third_party/protobuf/m4/stl_hash.m4 b/third_party/protobuf/m4/stl_hash.m4 |
new file mode 100644 |
index 0000000000000000000000000000000000000000..0722b14a73daa9eddd1b73f1854f1abcfef762b5 |
--- /dev/null |
+++ b/third_party/protobuf/m4/stl_hash.m4 |
@@ -0,0 +1,72 @@ |
+# We check two things: where the include file is for |
+# unordered_map/hash_map (we prefer the first form), and what |
+# namespace unordered/hash_map lives in within that include file. We |
+# include AC_TRY_COMPILE for all the combinations we've seen in the |
+# wild. We define HASH_MAP_H to the location of the header file, and |
+# HASH_NAMESPACE to the namespace the class (unordered_map or |
+# hash_map) is in. We define HAVE_UNORDERED_MAP if the class we found |
+# is named unordered_map, or leave it undefined if not. |
+ |
+# This also checks if unordered map exists. |
+AC_DEFUN([AC_CXX_STL_HASH], |
+ [ |
+ AC_MSG_CHECKING(the location of hash_map) |
+ AC_LANG_SAVE |
+ AC_LANG_CPLUSPLUS |
+ ac_cv_cxx_hash_map="" |
+ # First try unordered_map, but not on gcc's before 4.2 -- I've |
+ # seen unexplainable unordered_map bugs with -O2 on older gcc's. |
+ AC_TRY_COMPILE([#if defined(__GNUC__) && (__GNUC__ < 4 || (__GNUC__ == 4 && __GNUC_MINOR__ < 2)) |
+ # error GCC too old for unordered_map |
+ #endif |
+ ], |
+ [/* no program body necessary */], |
+ [stl_hash_old_gcc=no], |
+ [stl_hash_old_gcc=yes]) |
+ for location in unordered_map tr1/unordered_map; do |
+ for namespace in std std::tr1; do |
+ if test -z "$ac_cv_cxx_hash_map" -a "$stl_hash_old_gcc" != yes; then |
+ # Some older gcc's have a buggy tr1, so test a bit of code. |
+ AC_TRY_COMPILE([#include <$location>], |
+ [const ${namespace}::unordered_map<int, int> t; |
+ return t.find(5) == t.end();], |
+ [ac_cv_cxx_hash_map="<$location>"; |
+ ac_cv_cxx_hash_namespace="$namespace"; |
+ ac_cv_cxx_hash_map_class="unordered_map";]) |
+ fi |
+ done |
+ done |
+ # Now try hash_map |
+ for location in ext/hash_map hash_map; do |
+ for namespace in __gnu_cxx "" std stdext; do |
+ if test -z "$ac_cv_cxx_hash_map"; then |
+ AC_TRY_COMPILE([#include <$location>], |
+ [${namespace}::hash_map<int, int> t], |
+ [ac_cv_cxx_hash_map="<$location>"; |
+ ac_cv_cxx_hash_namespace="$namespace"; |
+ ac_cv_cxx_hash_map_class="hash_map";]) |
+ fi |
+ done |
+ done |
+ ac_cv_cxx_hash_set=`echo "$ac_cv_cxx_hash_map" | sed s/map/set/`; |
+ ac_cv_cxx_hash_set_class=`echo "$ac_cv_cxx_hash_map_class" | sed s/map/set/`; |
+ if test -n "$ac_cv_cxx_hash_map"; then |
+ AC_DEFINE(HAVE_HASH_MAP, 1, [define if the compiler has hash_map]) |
+ AC_DEFINE(HAVE_HASH_SET, 1, [define if the compiler has hash_set]) |
+ AC_DEFINE_UNQUOTED(HASH_MAP_H,$ac_cv_cxx_hash_map, |
+ [the location of <unordered_map> or <hash_map>]) |
+ AC_DEFINE_UNQUOTED(HASH_SET_H,$ac_cv_cxx_hash_set, |
+ [the location of <unordered_set> or <hash_set>]) |
+ AC_DEFINE_UNQUOTED(HASH_NAMESPACE,$ac_cv_cxx_hash_namespace, |
+ [the namespace of hash_map/hash_set]) |
+ AC_DEFINE_UNQUOTED(HASH_MAP_CLASS,$ac_cv_cxx_hash_map_class, |
+ [the name of <hash_map>]) |
+ AC_DEFINE_UNQUOTED(HASH_SET_CLASS,$ac_cv_cxx_hash_set_class, |
+ [the name of <hash_set>]) |
+ AC_MSG_RESULT([$ac_cv_cxx_hash_map]) |
+ else |
+ AC_MSG_RESULT() |
+ AC_MSG_WARN([could not find an STL hash_map]) |
+ fi |
+]) |
+ |