1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
|
# hypot.m4 serial 3
dnl Copyright (C) 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.
AC_DEFUN([gl_FUNC_HYPOT],
[
m4_divert_text([DEFAULTS], [gl_hypot_required=plain])
AC_REQUIRE([gl_MATH_H_DEFAULTS])
dnl Persuade glibc <math.h> to declare hypot().
AC_REQUIRE([gl_USE_SYSTEM_EXTENSIONS])
dnl Determine HYPOT_LIBM.
gl_COMMON_DOUBLE_MATHFUNC([hypot])
m4_ifdef([gl_FUNC_HYPOT_IEEE], [
if test $gl_hypot_required = ieee && test $REPLACE_HYPOT = 0; then
AC_CACHE_CHECK([whether hypot works according to ISO C 99 with IEC 60559],
[gl_cv_func_hypot_ieee],
[
save_LIBS="$LIBS"
LIBS="$LIBS $HYPOT_LIBM"
AC_RUN_IFELSE(
[AC_LANG_SOURCE([[
#ifndef __NO_MATH_INLINES
# define __NO_MATH_INLINES 1 /* for glibc */
#endif
#include <math.h>
/* Compare two numbers with ==.
This is a separate function because IRIX 6.5 "cc -O" miscompiles an
'x == x' test. */
static int
numeric_equal (double x, double y)
{
return x == y;
}
static double dummy (double x, double y) { return 0; }
double zero;
double one = 1.0;
int main (int argc, char *argv[])
{
double (*my_hypot) (double, double) = argc ? hypot : dummy;
double f;
/* Test hypot(NaN,Infinity).
This test fails on OSF/1 5.1 and native Windows. */
f = my_hypot (zero / zero, one / zero);
if (!numeric_equal (f, f))
return 1;
return 0;
}
]])],
[gl_cv_func_hypot_ieee=yes],
[gl_cv_func_hypot_ieee=no],
[gl_cv_func_hypot_ieee="guessing no"])
LIBS="$save_LIBS"
])
case "$gl_cv_func_hypot_ieee" in
*yes) ;;
*) REPLACE_HYPOT=1 ;;
esac
fi
])
if test $REPLACE_HYPOT = 1; then
dnl Find libraries needed to link lib/hypot.c.
AC_REQUIRE([gl_FUNC_FABS])
AC_REQUIRE([gl_FUNC_FREXP])
AC_REQUIRE([gl_FUNC_LDEXP])
AC_REQUIRE([gl_FUNC_SQRT])
HYPOT_LIBM=
dnl Append $FABS_LIBM to HYPOT_LIBM, avoiding gratuitous duplicates.
case " $HYPOT_LIBM " in
*" $FABS_LIBM "*) ;;
*) HYPOT_LIBM="$HYPOT_LIBM $FABS_LIBM" ;;
esac
dnl Append $FREXP_LIBM to HYPOT_LIBM, avoiding gratuitous duplicates.
case " $HYPOT_LIBM " in
*" $FREXP_LIBM "*) ;;
*) HYPOT_LIBM="$HYPOT_LIBM $FREXP_LIBM" ;;
esac
dnl Append $LDEXP_LIBM to HYPOT_LIBM, avoiding gratuitous duplicates.
case " $HYPOT_LIBM " in
*" $LDEXP_LIBM "*) ;;
*) HYPOT_LIBM="$HYPOT_LIBM $LDEXP_LIBM" ;;
esac
dnl Append $SQRT_LIBM to HYPOT_LIBM, avoiding gratuitous duplicates.
case " $HYPOT_LIBM " in
*" $SQRT_LIBM "*) ;;
*) HYPOT_LIBM="$HYPOT_LIBM $SQRT_LIBM" ;;
esac
fi
])
|