parent
b4d64bf7f3
commit
1fd96c43a0
6 changed files with 108 additions and 54 deletions
@ -1,60 +1,72 @@ |
|||||||
# We check two things: where the include file is for hash_map, and |
# We check two things: where the include file is for |
||||||
# what namespace hash_map lives in within that include file. We |
# 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 |
# include AC_TRY_COMPILE for all the combinations we've seen in the |
||||||
# wild. We define one of HAVE_HASH_MAP or HAVE_EXT_HASH_MAP depending |
# wild. We define HASH_MAP_H to the location of the header file, and |
||||||
# on location, and HASH_NAMESPACE to be the namespace hash_map is |
# HASH_NAMESPACE to the namespace the class (unordered_map or |
||||||
# defined in. |
# hash_map) is in. We define HAVE_UNORDERED_MAP if the class we found |
||||||
# |
# is named unordered_map, or leave it undefined if not. |
||||||
# Ideally we'd use AC_CACHE_CHECK, but that only lets us store one value |
|
||||||
# at a time, and we need to store two (filename and namespace). |
|
||||||
# prints messages itself, so we have to do the message-printing ourselves |
|
||||||
# via AC_MSG_CHECKING + AC_MSG_RESULT. (TODO(csilvers): can we cache?) |
|
||||||
|
|
||||||
|
# This also checks if unordered map exists. |
||||||
AC_DEFUN([AC_CXX_STL_HASH], |
AC_DEFUN([AC_CXX_STL_HASH], |
||||||
[AC_MSG_CHECKING(the location of hash_map) |
[ |
||||||
AC_LANG_SAVE |
AC_MSG_CHECKING(the location of hash_map) |
||||||
|
AC_LANG_SAVE |
||||||
AC_LANG_CPLUSPLUS |
AC_LANG_CPLUSPLUS |
||||||
ac_cv_cxx_hash_map_header="" |
ac_cv_cxx_hash_map="" |
||||||
ac_cv_cxx_hash_map_class="" |
# First try unordered_map, but not on gcc's before 4.2 -- I've |
||||||
for location in [tr1/unordered_map ext/hash_map hash_map]; do |
# seen unexplainable unordered_map bugs with -O2 on older gcc's. |
||||||
for namespace in [std::tr1 __gnu_cxx "" std stdext]; do |
AC_TRY_COMPILE([#if defined(__GNUC__) && (__GNUC__ < 4 || (__GNUC__ == 4 && __GNUC_MINOR__ < 2)) |
||||||
for name in [unordered_map hash_map]; do |
# error GCC too old for unordered_map |
||||||
|
#endif |
||||||
if test -z "$ac_cv_cxx_hash_map_header"; then |
], |
||||||
|
[/* no program body necessary */], |
||||||
# On OSX 1.5 / GCC 4.0.1 (the standard compiler on that platform), |
[stl_hash_old_gcc=no], |
||||||
# calling find() on a const unordered_map does not compile. So, we |
[stl_hash_old_gcc=yes]) |
||||||
# include a call to find() in our test to detect this broken |
for location in unordered_map tr1/unordered_map; do |
||||||
# implementation and avoid using it. Note that ext/hash_map works |
for namespace in std std::tr1; do |
||||||
# fine on this platform, so we'll end up using that. |
if test -z "$ac_cv_cxx_hash_map" -a "$stl_hash_old_gcc" != yes; then |
||||||
AC_TRY_COMPILE([#include <$location>], |
# Some older gcc's have a buggy tr1, so test a bit of code. |
||||||
[const ${namespace}::$name<int, int> t; |
AC_TRY_COMPILE([#include <$location>], |
||||||
t.find(1);], |
[const ${namespace}::unordered_map<int, int> t; |
||||||
[ac_cv_cxx_hash_map_header="<$location>"; |
return t.find(5) == t.end();], |
||||||
ac_cv_cxx_hash_namespace="$namespace"; |
[ac_cv_cxx_hash_map="<$location>"; |
||||||
ac_cv_cxx_hash_map_class="$name";]) |
ac_cv_cxx_hash_namespace="$namespace"; |
||||||
fi |
ac_cv_cxx_hash_map_class="unordered_map";]) |
||||||
done |
fi |
||||||
done |
done |
||||||
done |
done |
||||||
ac_cv_cxx_hash_set_header=`echo "$ac_cv_cxx_hash_map_header" | sed s/map/set/`; |
# 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/`; |
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_header"; then |
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_MAP, 1, [define if the compiler has hash_map]) |
||||||
AC_DEFINE(HAVE_HASH_SET, 1, [define if the compiler has hash_set]) |
AC_DEFINE(HAVE_HASH_SET, 1, [define if the compiler has hash_set]) |
||||||
AC_DEFINE_UNQUOTED(HASH_MAP_H,$ac_cv_cxx_hash_map_header, |
AC_DEFINE_UNQUOTED(HASH_MAP_H,$ac_cv_cxx_hash_map, |
||||||
[the location of <hash_map>]) |
[the location of <unordered_map> or <hash_map>]) |
||||||
AC_DEFINE_UNQUOTED(HASH_SET_H,$ac_cv_cxx_hash_set_header, |
AC_DEFINE_UNQUOTED(HASH_SET_H,$ac_cv_cxx_hash_set, |
||||||
[the location of <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, |
AC_DEFINE_UNQUOTED(HASH_MAP_CLASS,$ac_cv_cxx_hash_map_class, |
||||||
[the name of <hash_set>]) |
[the name of <hash_map>]) |
||||||
AC_DEFINE_UNQUOTED(HASH_SET_CLASS,$ac_cv_cxx_hash_set_class, |
AC_DEFINE_UNQUOTED(HASH_SET_CLASS,$ac_cv_cxx_hash_set_class, |
||||||
[the name of <hash_set>]) |
[the name of <hash_set>]) |
||||||
AC_DEFINE_UNQUOTED(HASH_NAMESPACE,$ac_cv_cxx_hash_namespace, |
AC_MSG_RESULT([$ac_cv_cxx_hash_map]) |
||||||
[the namespace of hash_map/hash_set]) |
|
||||||
AC_MSG_RESULT([$ac_cv_cxx_hash_map_header]) |
|
||||||
else |
else |
||||||
AC_MSG_RESULT() |
AC_MSG_RESULT() |
||||||
AC_MSG_WARN([could not find an STL hash_map]) |
AC_MSG_WARN([could not find an STL hash_map]) |
||||||
fi |
fi |
||||||
]) |
]) |
||||||
|
|
||||||
|
Loading…
Reference in new issue