X-Git-Url: http://erislabs.net/gitweb/?a=blobdiff_plain;f=m4%2Fexpl.m4;h=a94b2b18f2189a4fad49f94f71b46ee9da46cad6;hb=270e2d3e2966d9a5bc16dd0b367b71740b8994d5;hp=c9c1b7b9ed2038f1934a1f3ae43fef9c71f4c8af;hpb=d959bf1ca51cddcd5810a1be44e3391c8965dd59;p=gnulib.git diff --git a/m4/expl.m4 b/m4/expl.m4 index c9c1b7b9e..a94b2b18f 100644 --- a/m4/expl.m4 +++ b/m4/expl.m4 @@ -1,5 +1,5 @@ -# expl.m4 serial 4 -dnl Copyright (C) 2010-2011 Free Software Foundation, Inc. +# expl.m4 serial 7 +dnl Copyright (C) 2010-2012 Free Software Foundation, Inc. dnl This file is free software; the Free Software Foundation dnl gives unlimited permission to copy and/or distribute it, dnl with or without modifications, as long as this notice is preserved. @@ -7,6 +7,8 @@ dnl with or without modifications, as long as this notice is preserved. AC_DEFUN([gl_FUNC_EXPL], [ AC_REQUIRE([gl_MATH_H_DEFAULTS]) + AC_REQUIRE([gl_LONG_DOUBLE_VS_DOUBLE]) + dnl Persuade glibc to declare expl(). AC_REQUIRE([gl_USE_SYSTEM_EXTENSIONS]) @@ -20,8 +22,10 @@ AC_DEFUN([gl_FUNC_EXPL], # define __NO_MATH_INLINES 1 /* for glibc */ #endif #include + long double (*funcptr) (long double) = expl; long double x;]], - [[return expl (x) > 1.5;]])], + [[return funcptr (x) > 1.5 + || expl (x) > 1.5;]])], [gl_cv_func_expl_no_libm=yes], [gl_cv_func_expl_no_libm=no]) ]) @@ -37,8 +41,10 @@ AC_DEFUN([gl_FUNC_EXPL], # define __NO_MATH_INLINES 1 /* for glibc */ #endif #include + long double (*funcptr) (long double) = expl; long double x;]], - [[return expl (x) > 1.5;]])], + [[return funcptr (x) > 1.5 + || expl (x) > 1.5;]])], [gl_cv_func_expl_in_libm=yes], [gl_cv_func_expl_in_libm=no]) LIBS="$save_LIBS" @@ -56,8 +62,30 @@ AC_DEFUN([gl_FUNC_EXPL], HAVE_DECL_EXPL=0 HAVE_EXPL=0 dnl Find libraries needed to link lib/expl.c. - AC_REQUIRE([gl_FUNC_FLOORL]) - EXPL_LIBM="$FLOORL_LIBM" + if test $HAVE_SAME_LONG_DOUBLE_AS_DOUBLE = 1; then + AC_REQUIRE([gl_FUNC_EXP]) + EXPL_LIBM="$EXP_LIBM" + else + AC_REQUIRE([gl_FUNC_ISNANL]) + AC_REQUIRE([gl_FUNC_ROUNDL]) + AC_REQUIRE([gl_FUNC_LDEXPL]) + EXPL_LIBM= + dnl Append $ISNANL_LIBM to EXPL_LIBM, avoiding gratuitous duplicates. + case " $EXPL_LIBM " in + *" $ISNANL_LIBM "*) ;; + *) EXPL_LIBM="$EXPL_LIBM $ISNANL_LIBM" ;; + esac + dnl Append $ROUNDL_LIBM to EXPL_LIBM, avoiding gratuitous duplicates. + case " $EXPL_LIBM " in + *" $ROUNDL_LIBM "*) ;; + *) EXPL_LIBM="$EXPL_LIBM $ROUNDL_LIBM" ;; + esac + dnl Append $LDEXPL_LIBM to EXPL_LIBM, avoiding gratuitous duplicates. + case " $EXPL_LIBM " in + *" $LDEXPL_LIBM "*) ;; + *) EXPL_LIBM="$EXPL_LIBM $LDEXPL_LIBM" ;; + esac + fi fi AC_SUBST([EXPL_LIBM]) ])