X-Git-Url: http://erislabs.net/gitweb/?a=blobdiff_plain;f=m4%2Fxstrtoumax.m4;h=7899ca130595e55ee3527b9f4d45ca93464d8e61;hb=c27f394b70a4af807ab515fa92cc764fd2e64d4b;hp=842d7292a2b6c189055c60e150d4ea93088e4aaf;hpb=3932f7dad2c464a97d8c36955c68b969ee84be61;p=gnulib.git diff --git a/m4/xstrtoumax.m4 b/m4/xstrtoumax.m4 index 842d7292a..7899ca130 100644 --- a/m4/xstrtoumax.m4 +++ b/m4/xstrtoumax.m4 @@ -1,21 +1,33 @@ -#serial 1 +#serial 2 # autoconf tests required for use of xstrtoumax.c AC_DEFUN(jm_AC_PREREQ_XSTRTOUMAX, [ + AC_REQUIRE([jm_AC_TYPE_UINTMAX_T]) AC_REQUIRE([jm_AC_HEADER_INTTYPES_H]) AC_REQUIRE([jm_AC_TYPE_UNSIGNED_LONG_LONG]) AC_CHECK_HEADERS(stdlib.h) - AC_CHECK_FUNCS(strtoull strtoumax strtouq) - AC_REPLACE_FUNCS(strtoumax) + + AC_CACHE_CHECK([whether defines strtoumax as a macro], + jm_cv_func_strtoumax_macro, + AC_EGREP_CPP([inttypes_h_defines_strtoumax], [#include +#ifdef strtoumax + inttypes_h_defines_strtoumax +#endif], + jm_cv_func_strtoumax_macro=yes, + jm_cv_func_strtoumax_macro=no)) + + if test "$jm_cv_func_strtoumax_macro" != yes; then + AC_REPLACE_FUNCS(strtoumax) + fi dnl We don't need (and can't compile) the replacement strtoull dnl unless the type `unsigned long long' exists. dnl Also, only the replacement strtoumax invokes strtoull, dnl so we need the replacement strtoull only if strtoumax does not exist. - case "$ac_cv_type_unsigned_long_long,$ac_cv_func_strtoumax" in - yes,no) + case "$ac_cv_type_unsigned_long_long,$jm_cv_func_strtoumax_macro,$ac_cv_func_strtoumax" in + yes,no,no) AC_REPLACE_FUNCS(strtoull) ;; esac