X-Git-Url: https://erislabs.net/gitweb/?a=blobdiff_plain;f=m4%2Fsinl.m4;h=43b27e82305bc5bb449fe8eaad1cfcf0f4d8b680;hb=da8054d48dc22e1c051db54049e005d51a006e69;hp=c9c0e5c48e4b26a46d9fe2053808902dc4dfaa50;hpb=b4349b948ba2c352187158e241334abda6e473e9;p=gnulib.git diff --git a/m4/sinl.m4 b/m4/sinl.m4 index c9c0e5c48..43b27e823 100644 --- a/m4/sinl.m4 +++ b/m4/sinl.m4 @@ -1,5 +1,5 @@ -# sinl.m4 serial 2 -dnl Copyright (C) 2010 Free Software Foundation, Inc. +# sinl.m4 serial 8 +dnl Copyright (C) 2010-2013 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_SINL], [ AC_REQUIRE([gl_MATH_H_DEFAULTS]) + AC_REQUIRE([gl_LONG_DOUBLE_VS_DOUBLE]) + dnl Persuade glibc to declare sinl(). AC_REQUIRE([gl_USE_SYSTEM_EXTENSIONS]) @@ -14,12 +16,16 @@ AC_DEFUN([gl_FUNC_SINL], AC_CACHE_CHECK([whether sinl() can be used without linking with libm], [gl_cv_func_sinl_no_libm], [ - AC_TRY_LINK([#ifndef __NO_MATH_INLINES - # define __NO_MATH_INLINES 1 /* for glibc */ - #endif - #include - long double x;], - [return sinl (x) > 0.4;], + AC_LINK_IFELSE( + [AC_LANG_PROGRAM( + [[#ifndef __NO_MATH_INLINES + # define __NO_MATH_INLINES 1 /* for glibc */ + #endif + #include + long double (*funcptr) (long double) = sinl; + long double x;]], + [[return funcptr (x) > 0.4 + || sinl (x) > 0.4;]])], [gl_cv_func_sinl_no_libm=yes], [gl_cv_func_sinl_no_libm=no]) ]) @@ -29,12 +35,16 @@ AC_DEFUN([gl_FUNC_SINL], [ save_LIBS="$LIBS" LIBS="$LIBS -lm" - AC_TRY_LINK([#ifndef __NO_MATH_INLINES - # define __NO_MATH_INLINES 1 /* for glibc */ - #endif - #include - long double x;], - [return sinl (x) > 0.4;], + AC_LINK_IFELSE( + [AC_LANG_PROGRAM( + [[#ifndef __NO_MATH_INLINES + # define __NO_MATH_INLINES 1 /* for glibc */ + #endif + #include + long double (*funcptr) (long double) = sinl; + long double x;]], + [[return funcptr (x) > 0.4 + || sinl (x) > 0.4;]])], [gl_cv_func_sinl_in_libm=yes], [gl_cv_func_sinl_in_libm=no]) LIBS="$save_LIBS" @@ -46,32 +56,35 @@ AC_DEFUN([gl_FUNC_SINL], if test $gl_cv_func_sinl_no_libm = yes \ || test $gl_cv_func_sinl_in_libm = yes; then dnl Also check whether it's declared. - dnl MacOS X 10.3 has sinl() in libc but doesn't declare it in . - AC_CHECK_DECL([sinl], , [HAVE_DECL_SINL=0], [#include ]) + dnl Mac OS X 10.3 has sinl() in libc but doesn't declare it in . + AC_CHECK_DECL([sinl], , [HAVE_DECL_SINL=0], [[#include ]]) else HAVE_DECL_SINL=0 HAVE_SINL=0 - AC_LIBOBJ([sinl]) - AC_LIBOBJ([sincosl]) - AC_LIBOBJ([trigl]) - AC_REQUIRE([gl_FUNC_ISNANL]) - AC_REQUIRE([gl_FUNC_FLOOR]) - AC_REQUIRE([gl_FUNC_FLOORL]) - dnl Append $ISNANL_LIBM to SINL_LIBM, avoiding gratuitous duplicates. - case " $SINL_LIBM " in - *" $ISNANL_LIBM "*) ;; - *) SINL_LIBM="$SINL_LIBM $ISNANL_LIBM" ;; - esac - dnl Append $FLOOR_LIBM to SINL_LIBM, avoiding gratuitous duplicates. - case " $SINL_LIBM " in - *" $FLOOR_LIBM "*) ;; - *) SINL_LIBM="$SINL_LIBM $FLOOR_LIBM" ;; - esac - dnl Append $FLOORL_LIBM to SINL_LIBM, avoiding gratuitous duplicates. - case " $SINL_LIBM " in - *" $FLOORL_LIBM "*) ;; - *) SINL_LIBM="$SINL_LIBM $FLOORL_LIBM" ;; - esac + dnl Find libraries needed to link lib/sinl.c, lib/sincosl.c, lib/trigl.c. + if test $HAVE_SAME_LONG_DOUBLE_AS_DOUBLE = 1; then + AC_REQUIRE([gl_FUNC_SIN]) + SINL_LIBM="$SIN_LIBM" + else + AC_REQUIRE([gl_FUNC_ISNANL]) + AC_REQUIRE([gl_FUNC_FLOOR]) + AC_REQUIRE([gl_FUNC_FLOORL]) + dnl Append $ISNANL_LIBM to SINL_LIBM, avoiding gratuitous duplicates. + case " $SINL_LIBM " in + *" $ISNANL_LIBM "*) ;; + *) SINL_LIBM="$SINL_LIBM $ISNANL_LIBM" ;; + esac + dnl Append $FLOOR_LIBM to SINL_LIBM, avoiding gratuitous duplicates. + case " $SINL_LIBM " in + *" $FLOOR_LIBM "*) ;; + *) SINL_LIBM="$SINL_LIBM $FLOOR_LIBM" ;; + esac + dnl Append $FLOORL_LIBM to SINL_LIBM, avoiding gratuitous duplicates. + case " $SINL_LIBM " in + *" $FLOORL_LIBM "*) ;; + *) SINL_LIBM="$SINL_LIBM $FLOORL_LIBM" ;; + esac + fi fi AC_SUBST([SINL_LIBM]) ])