2 dnl Copyright (C) 2012-2017 Free Software Foundation, Inc.
3 dnl This file is free software; the Free Software Foundation
4 dnl gives unlimited permission to copy and/or distribute it,
5 dnl with or without modifications, as long as this notice is preserved.
7 AC_DEFUN([gl_FUNC_LOG1P],
9 m4_divert_text([DEFAULTS], [gl_log1p_required=plain])
10 AC_REQUIRE([gl_MATH_H_DEFAULTS])
12 dnl Persuade glibc <math.h> to declare log1p().
13 AC_REQUIRE([gl_USE_SYSTEM_EXTENSIONS])
15 dnl Determine LOG1P_LIBM.
16 gl_COMMON_DOUBLE_MATHFUNC([log1p])
18 dnl Test whether log1p() exists.
20 LIBS="$LIBS $LOG1P_LIBM"
21 AC_CHECK_FUNCS([log1p])
23 if test $ac_cv_func_log1p = yes; then
25 m4_ifdef([gl_FUNC_LOG1P_IEEE], [
26 if test $gl_log1p_required = ieee && test $REPLACE_LOG1P = 0; then
27 AC_REQUIRE([AC_CANONICAL_HOST]) dnl for cross-compiles
28 AC_CACHE_CHECK([whether log1p works according to ISO C 99 with IEC 60559],
29 [gl_cv_func_log1p_ieee],
32 LIBS="$LIBS $LOG1P_LIBM"
35 #ifndef __NO_MATH_INLINES
36 # define __NO_MATH_INLINES 1 /* for glibc */
39 ]gl_DOUBLE_MINUS_ZERO_CODE[
40 ]gl_DOUBLE_SIGNBIT_CODE[
41 static double dummy (double x) { return 0; }
42 int main (int argc, char *argv[])
44 double (*my_log1p) (double) = argc ? log1p : dummy;
45 /* This test fails on AIX, HP-UX 11. */
46 double y = my_log1p (minus_zerod);
47 if (!(y == 0.0) || (signbitd (minus_zerod) && !signbitd (y)))
52 [gl_cv_func_log1p_ieee=yes],
53 [gl_cv_func_log1p_ieee=no],
55 # Guess yes on glibc systems.
56 *-gnu*) gl_cv_func_log1p_ieee="guessing yes" ;;
57 # Guess yes on native Windows.
58 mingw*) gl_cv_func_log1p_ieee="guessing yes" ;;
59 # If we don't know, assume the worst.
60 *) gl_cv_func_log1p_ieee="guessing no" ;;
65 case "$gl_cv_func_log1p_ieee" in
74 if test $HAVE_LOG1P = 0 || test $REPLACE_LOG1P = 1; then
75 dnl Find libraries needed to link lib/log1p.c.
76 AC_REQUIRE([gl_FUNC_ISNAND])
77 AC_REQUIRE([gl_FUNC_LOG])
78 AC_REQUIRE([gl_FUNC_ROUND])
80 dnl Append $ISNAND_LIBM to LOG1P_LIBM, avoiding gratuitous duplicates.
81 case " $LOG1P_LIBM " in
82 *" $ISNAND_LIBM "*) ;;
83 *) LOG1P_LIBM="$LOG1P_LIBM $ISNAND_LIBM" ;;
85 dnl Append $LOG_LIBM to LOG1P_LIBM, avoiding gratuitous duplicates.
86 case " $LOG1P_LIBM " in
88 *) LOG1P_LIBM="$LOG1P_LIBM $LOG_LIBM" ;;
90 dnl Append $ROUND_LIBM to LOG1P_LIBM, avoiding gratuitous duplicates.
91 case " $LOG1P_LIBM " in
93 *) LOG1P_LIBM="$LOG1P_LIBM $ROUND_LIBM" ;;