2 dnl Copyright (C) 2011-2018 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_FMOD],
9 m4_divert_text([DEFAULTS], [gl_fmod_required=plain])
10 AC_REQUIRE([gl_MATH_H_DEFAULTS])
12 dnl Determine FMOD_LIBM.
13 gl_COMMON_DOUBLE_MATHFUNC([fmod])
15 m4_ifdef([gl_FUNC_FMOD_IEEE], [
16 if test $gl_fmod_required = ieee && test $REPLACE_FMOD = 0; then
17 AC_REQUIRE([AC_CANONICAL_HOST]) dnl for cross-compiles
18 AC_CACHE_CHECK([whether fmod works according to ISO C 99 with IEC 60559],
19 [gl_cv_func_fmod_ieee],
22 LIBS="$LIBS $FMOD_LIBM"
25 #ifndef __NO_MATH_INLINES
26 # define __NO_MATH_INLINES 1 /* for glibc */
29 ]gl_DOUBLE_MINUS_ZERO_CODE[
30 ]gl_DOUBLE_SIGNBIT_CODE[
31 /* Compare two numbers with ==.
32 This is a separate function because IRIX 6.5 "cc -O" miscompiles an
35 numeric_equal (double x, double y)
39 static double dummy (double x, double y) { return 0; }
40 int main (int argc, char *argv[])
42 double (*my_fmod) (double, double) = argc ? fmod : dummy;
45 /* Test fmod(...,0.0).
46 This test fails on OSF/1 5.1. */
47 f = my_fmod (2.0, 0.0);
48 if (numeric_equal (f, f))
50 /* Test fmod(-0.0,...).
51 This test fails on native Windows. */
52 f = my_fmod (minus_zerod, 2.0);
53 if (!(f == 0.0) || (signbitd (minus_zerod) && !signbitd (f)))
58 [gl_cv_func_fmod_ieee=yes],
59 [gl_cv_func_fmod_ieee=no],
61 # Guess yes on glibc systems.
62 *-gnu* | gnu*) gl_cv_func_fmod_ieee="guessing yes" ;;
63 # Guess yes on native Windows.
64 mingw*) gl_cv_func_fmod_ieee="guessing yes" ;;
65 # If we don't know, assume the worst.
66 *) gl_cv_func_fmod_ieee="guessing no" ;;
71 case "$gl_cv_func_fmod_ieee" in
77 if test $REPLACE_FMOD = 1; then
78 dnl Find libraries needed to link lib/fmod.c.
79 AC_REQUIRE([gl_FUNC_FABS])
80 AC_REQUIRE([gl_FUNC_FREXP])
81 AC_REQUIRE([gl_FUNC_TRUNC])
82 AC_REQUIRE([gl_FUNC_LDEXP])
83 AC_REQUIRE([gl_FUNC_ISNAND])
85 dnl Append $FABS_LIBM to FMOD_LIBM, avoiding gratuitous duplicates.
86 case " $FMOD_LIBM " in
88 *) FMOD_LIBM="$FMOD_LIBM $FABS_LIBM" ;;
90 dnl Append $FREXP_LIBM to FMOD_LIBM, avoiding gratuitous duplicates.
91 case " $FMOD_LIBM " in
93 *) FMOD_LIBM="$FMOD_LIBM $FREXP_LIBM" ;;
95 dnl Append $TRUNC_LIBM to FMOD_LIBM, avoiding gratuitous duplicates.
96 case " $FMOD_LIBM " in
98 *) FMOD_LIBM="$FMOD_LIBM $TRUNC_LIBM" ;;
100 dnl Append $LDEXP_LIBM to FMOD_LIBM, avoiding gratuitous duplicates.
101 case " $FMOD_LIBM " in
102 *" $LDEXP_LIBM "*) ;;
103 *) FMOD_LIBM="$FMOD_LIBM $LDEXP_LIBM" ;;
105 dnl Append $ISNAND_LIBM to FMOD_LIBM, avoiding gratuitous duplicates.
106 case " $FMOD_LIBM " in
107 *" $ISNAND_LIBM "*) ;;
108 *) FMOD_LIBM="$FMOD_LIBM $ISNAND_LIBM" ;;