diff options
author | Jim Meyering <jim@meyering.net> | 1999-08-01 09:05:17 +0000 |
---|---|---|
committer | Jim Meyering <jim@meyering.net> | 1999-08-01 09:05:17 +0000 |
commit | 270f765604562342ac3cfdc06197ba91a08e2bb3 (patch) | |
tree | aa8c97f859fce366b3fa872580de53cc81460e0f | |
parent | d1ea83833160d61599b531cce907ddfdf6a526c2 (diff) | |
download | coreutils-270f765604562342ac3cfdc06197ba91a08e2bb3.tar.xz |
(jm_AC_PREREQ_XSTRTOUMAX): Check whether
<inttypes.h> defines strtoumax as a macro (and not as a
function).
-rw-r--r-- | m4/xstrtoumax.m4 | 20 |
1 files changed, 16 insertions, 4 deletions
diff --git a/m4/xstrtoumax.m4 b/m4/xstrtoumax.m4 index b9f27061c..f6e319968 100644 --- a/m4/xstrtoumax.m4 +++ b/m4/xstrtoumax.m4 @@ -1,4 +1,4 @@ -#serial 1 +#serial 2 # autoconf tests required for use of xstrtoumax.c @@ -7,14 +7,26 @@ AC_DEFUN(jm_AC_PREREQ_XSTRTOUMAX, AC_REQUIRE([jm_AC_HEADER_INTTYPES_H]) AC_REQUIRE([jm_AC_TYPE_UNSIGNED_LONG_LONG]) AC_CHECK_HEADERS(stdlib.h) - AC_REPLACE_FUNCS(strtoumax) + + AC_CACHE_CHECK([whether <inttypes.h> defines strtoumax as a macro], + jm_cv_func_strtoumax_macro, + AC_EGREP_CPP([inttypes_h_defines_strtoumax], [#include <inttypes.h> +#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 |