X-Git-Url: http://erislabs.net/gitweb/?a=blobdiff_plain;f=m4%2Fc-strtod.m4;h=b343fddae9a03d3233a194091fffe8b41897b541;hb=348925857a90662fb2bc8184f301ef16eff8ef80;hp=c212c5c9e38c0509947258754a26dc7930c37dee;hpb=184aaab6f9d672e5ba78820fbab68d89e0254470;p=gnulib.git diff --git a/m4/c-strtod.m4 b/m4/c-strtod.m4 index c212c5c9e..b343fddae 100644 --- a/m4/c-strtod.m4 +++ b/m4/c-strtod.m4 @@ -1,4 +1,4 @@ -# c-strtod.m4 serial 3 +# c-strtod.m4 serial 4 # Copyright (C) 2004 Free Software Foundation, Inc. @@ -18,6 +18,32 @@ # Written by Paul Eggert. +AC_DEFUN([gl_C99_STRTOLD], +[ + AC_CACHE_CHECK([whether strtold conforms to C99], + [gl_cv_func_c99_strtold], + [AC_COMPILE_IFELSE( + [AC_LANG_PROGRAM( + [[/* On HP-UX before 11.23, strtold returns a struct instead of + long double. Reject implementations like that, by requiring + compatibility with the C99 prototype. */ + #include + static long double (*p) (char const *, char **) = strtold; + static long double + test (char const *nptr, char **endptr) + { + long double r; + r = strtold (nptr, endptr); + return r; + }]], + [[return test ("1.0", NULL) != 1 || p ("1.0", NULL) != 1;]])], + [gl_cv_func_c99_strtold=yes], + [gl_cv_func_c99_strtold=no])]) + if test $gl_cv_func_c99_strtold = yes; then + AC_DEFINE([HAVE_C99_STRTOLD], 1, [Define to 1 if strtold conforms to C99.]) + fi +]) + AC_DEFUN([gl_C_STRTOD], [ dnl Prerequisites of lib/c-strtod.c. @@ -29,5 +55,6 @@ AC_DEFUN([gl_C_STRTOLD], [ dnl Prerequisites of lib/c-strtold.c. AC_REQUIRE([gl_C_STRTOD]) - AC_CHECK_DECLS_ONCE([strtold]) + AC_REQUIRE([gl_C99_STRTOLD]) + : ])