summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorJim Meyering <jim@meyering.net>1999-08-01 09:05:17 +0000
committerJim Meyering <jim@meyering.net>1999-08-01 09:05:17 +0000
commit59485dfa31c565faa152b2221894d3560d2b4374 (patch)
tree5944610a60bb4a62480fd3bb626672dd683a5496
parentaf29d1b9ebd824bd07e0051ef63cb3da5e465d2e (diff)
downloadgnulib-59485dfa31c565faa152b2221894d3560d2b4374.tar.gz
(jm_AC_PREREQ_XSTRTOUMAX): Check whether
<inttypes.h> defines strtoumax as a macro (and not as a function).
-rw-r--r--m4/xstrtoumax.m420
1 files changed, 16 insertions, 4 deletions
diff --git a/m4/xstrtoumax.m4 b/m4/xstrtoumax.m4
index b9f27061cd..f6e3199683 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