diff options
Diffstat (limited to 'gnulib/m4/cosl.m4')
m--------- | gnulib | 0 | ||||
-rw-r--r-- | gnulib/m4/cosl.m4 | 86 |
2 files changed, 86 insertions, 0 deletions
diff --git a/gnulib b/gnulib deleted file mode 160000 -Subproject 443bc5ffcf7429e557f4a371b0661abe98ddbc1 diff --git a/gnulib/m4/cosl.m4 b/gnulib/m4/cosl.m4 new file mode 100644 index 0000000..946d664 --- /dev/null +++ b/gnulib/m4/cosl.m4 @@ -0,0 +1,86 @@ +# cosl.m4 serial 6 +dnl Copyright (C) 2010-2011 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. + +AC_DEFUN([gl_FUNC_COSL], +[ + AC_REQUIRE([gl_MATH_H_DEFAULTS]) + AC_REQUIRE([gl_LONG_DOUBLE_VS_DOUBLE]) + + dnl Persuade glibc <math.h> to declare cosl(). + AC_REQUIRE([gl_USE_SYSTEM_EXTENSIONS]) + + COSL_LIBM= + AC_CACHE_CHECK([whether cosl() can be used without linking with libm], + [gl_cv_func_cosl_no_libm], + [ + AC_LINK_IFELSE( + [AC_LANG_PROGRAM( + [[#ifndef __NO_MATH_INLINES + # define __NO_MATH_INLINES 1 /* for glibc */ + #endif + #include <math.h> + long double x;]], + [[return cosl (x) > 0.4;]])], + [gl_cv_func_cosl_no_libm=yes], + [gl_cv_func_cosl_no_libm=no]) + ]) + if test $gl_cv_func_cosl_no_libm = no; then + AC_CACHE_CHECK([whether cosl() can be used with libm], + [gl_cv_func_cosl_in_libm], + [ + save_LIBS="$LIBS" + LIBS="$LIBS -lm" + AC_LINK_IFELSE( + [AC_LANG_PROGRAM( + [[#ifndef __NO_MATH_INLINES + # define __NO_MATH_INLINES 1 /* for glibc */ + #endif + #include <math.h> + long double x;]], + [[return cosl (x) > 0.4;]])], + [gl_cv_func_cosl_in_libm=yes], + [gl_cv_func_cosl_in_libm=no]) + LIBS="$save_LIBS" + ]) + if test $gl_cv_func_cosl_in_libm = yes; then + COSL_LIBM=-lm + fi + fi + if test $gl_cv_func_cosl_no_libm = yes \ + || test $gl_cv_func_cosl_in_libm = yes; then + dnl Also check whether it's declared. + dnl MacOS X 10.3 has cosl() in libc but doesn't declare it in <math.h>. + AC_CHECK_DECL([cosl], , [HAVE_DECL_COSL=0], [[#include <math.h>]]) + else + HAVE_DECL_COSL=0 + HAVE_COSL=0 + dnl Find libraries needed to link lib/cosl.c, lib/sincosl.c, lib/trigl.c. + if test $HAVE_SAME_LONG_DOUBLE_AS_DOUBLE = 1; then + AC_REQUIRE([gl_FUNC_COS]) + COSL_LIBM="$COS_LIBM" + else + AC_REQUIRE([gl_FUNC_ISNANL]) + AC_REQUIRE([gl_FUNC_FLOOR]) + AC_REQUIRE([gl_FUNC_FLOORL]) + dnl Append $ISNANL_LIBM to COSL_LIBM, avoiding gratuitous duplicates. + case " $COSL_LIBM " in + *" $ISNANL_LIBM "*) ;; + *) COSL_LIBM="$COSL_LIBM $ISNANL_LIBM" ;; + esac + dnl Append $FLOOR_LIBM to COSL_LIBM, avoiding gratuitous duplicates. + case " $COSL_LIBM " in + *" $FLOOR_LIBM "*) ;; + *) COSL_LIBM="$COSL_LIBM $FLOOR_LIBM" ;; + esac + dnl Append $FLOORL_LIBM to COSL_LIBM, avoiding gratuitous duplicates. + case " $COSL_LIBM " in + *" $FLOORL_LIBM "*) ;; + *) COSL_LIBM="$COSL_LIBM $FLOORL_LIBM" ;; + esac + fi + fi + AC_SUBST([COSL_LIBM]) +]) |