4
0

math_h.m4 4.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103
  1. # math_h.m4 serial 14
  2. dnl Copyright (C) 2007-2008 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.
  6. AC_DEFUN([gl_MATH_H],
  7. [
  8. AC_REQUIRE([gl_MATH_H_DEFAULTS])
  9. gl_CHECK_NEXT_HEADERS([math.h])
  10. AC_CACHE_CHECK([whether NAN macro works], [gl_cv_header_math_nan_works],
  11. [AC_COMPILE_IFELSE([AC_LANG_PROGRAM([[@%:@include <math.h>]],
  12. [[/* Solaris 10 has a broken definition of NAN. Other platforms
  13. fail to provide NAN, or provide it only in C99 mode; this
  14. test only needs to fail when NAN is provided but wrong. */
  15. float f = 1.0f;
  16. #ifdef NAN
  17. f = NAN;
  18. #endif
  19. return f == 0;]])],
  20. [gl_cv_header_math_nan_works=yes],
  21. [gl_cv_header_math_nan_works=no])])
  22. if test $gl_cv_header_math_nan_works = no; then
  23. REPLACE_NAN=1
  24. fi
  25. AC_CACHE_CHECK([whether HUGE_VAL works], [gl_cv_header_math_huge_val_works],
  26. [AC_COMPILE_IFELSE([AC_LANG_PROGRAM([[@%:@include <math.h>]],
  27. [[/* Solaris 10 has a broken definition of HUGE_VAL. */
  28. double d = HUGE_VAL;
  29. return d == 0;]])],
  30. [gl_cv_header_math_huge_val_works=yes],
  31. [gl_cv_header_math_huge_val_works=no])])
  32. if test $gl_cv_header_math_huge_val_works = no; then
  33. REPLACE_HUGE_VAL=1
  34. fi
  35. ])
  36. AC_DEFUN([gl_MATH_MODULE_INDICATOR],
  37. [
  38. dnl Use AC_REQUIRE here, so that the default settings are expanded once only.
  39. AC_REQUIRE([gl_MATH_H_DEFAULTS])
  40. GNULIB_[]m4_translit([$1],[abcdefghijklmnopqrstuvwxyz./-],[ABCDEFGHIJKLMNOPQRSTUVWXYZ___])=1
  41. ])
  42. AC_DEFUN([gl_MATH_H_DEFAULTS],
  43. [
  44. GNULIB_CEILF=0; AC_SUBST([GNULIB_CEILF])
  45. GNULIB_CEILL=0; AC_SUBST([GNULIB_CEILL])
  46. GNULIB_FLOORF=0; AC_SUBST([GNULIB_FLOORF])
  47. GNULIB_FLOORL=0; AC_SUBST([GNULIB_FLOORL])
  48. GNULIB_FREXP=0; AC_SUBST([GNULIB_FREXP])
  49. GNULIB_FREXPL=0; AC_SUBST([GNULIB_FREXPL])
  50. GNULIB_ISFINITE=0; AC_SUBST([GNULIB_ISFINITE])
  51. GNULIB_ISINF=0; AC_SUBST([GNULIB_ISINF])
  52. GNULIB_ISNAN=0; AC_SUBST([GNULIB_ISNAN])
  53. GNULIB_ISNANF=0; AC_SUBST([GNULIB_ISNANF])
  54. GNULIB_ISNAND=0; AC_SUBST([GNULIB_ISNAND])
  55. GNULIB_ISNANL=0; AC_SUBST([GNULIB_ISNANL])
  56. GNULIB_LDEXPL=0; AC_SUBST([GNULIB_LDEXPL])
  57. GNULIB_MATHL=0; AC_SUBST([GNULIB_MATHL])
  58. GNULIB_ROUND=0; AC_SUBST([GNULIB_ROUND])
  59. GNULIB_ROUNDF=0; AC_SUBST([GNULIB_ROUNDF])
  60. GNULIB_ROUNDL=0; AC_SUBST([GNULIB_ROUNDL])
  61. GNULIB_SIGNBIT=0; AC_SUBST([GNULIB_SIGNBIT])
  62. GNULIB_TRUNC=0; AC_SUBST([GNULIB_TRUNC])
  63. GNULIB_TRUNCF=0; AC_SUBST([GNULIB_TRUNCF])
  64. GNULIB_TRUNCL=0; AC_SUBST([GNULIB_TRUNCL])
  65. dnl Assume proper GNU behavior unless another module says otherwise.
  66. HAVE_ISNANF=1; AC_SUBST([HAVE_ISNANF])
  67. HAVE_ISNAND=1; AC_SUBST([HAVE_ISNAND])
  68. HAVE_ISNANL=1; AC_SUBST([HAVE_ISNANL])
  69. HAVE_DECL_ACOSL=1; AC_SUBST([HAVE_DECL_ACOSL])
  70. HAVE_DECL_ASINL=1; AC_SUBST([HAVE_DECL_ASINL])
  71. HAVE_DECL_ATANL=1; AC_SUBST([HAVE_DECL_ATANL])
  72. HAVE_DECL_COSL=1; AC_SUBST([HAVE_DECL_COSL])
  73. HAVE_DECL_EXPL=1; AC_SUBST([HAVE_DECL_EXPL])
  74. HAVE_DECL_FREXPL=1; AC_SUBST([HAVE_DECL_FREXPL])
  75. HAVE_DECL_LDEXPL=1; AC_SUBST([HAVE_DECL_LDEXPL])
  76. HAVE_DECL_LOGL=1; AC_SUBST([HAVE_DECL_LOGL])
  77. HAVE_DECL_SINL=1; AC_SUBST([HAVE_DECL_SINL])
  78. HAVE_DECL_SQRTL=1; AC_SUBST([HAVE_DECL_SQRTL])
  79. HAVE_DECL_TANL=1; AC_SUBST([HAVE_DECL_TANL])
  80. HAVE_DECL_TRUNC=1; AC_SUBST([HAVE_DECL_TRUNC])
  81. HAVE_DECL_TRUNCF=1; AC_SUBST([HAVE_DECL_TRUNCF])
  82. REPLACE_CEILF=0; AC_SUBST([REPLACE_CEILF])
  83. REPLACE_CEILL=0; AC_SUBST([REPLACE_CEILL])
  84. REPLACE_FLOORF=0; AC_SUBST([REPLACE_FLOORF])
  85. REPLACE_FLOORL=0; AC_SUBST([REPLACE_FLOORL])
  86. REPLACE_FREXP=0; AC_SUBST([REPLACE_FREXP])
  87. REPLACE_FREXPL=0; AC_SUBST([REPLACE_FREXPL])
  88. REPLACE_HUGE_VAL=0; AC_SUBST([REPLACE_HUGE_VAL])
  89. REPLACE_ISFINITE=0; AC_SUBST([REPLACE_ISFINITE])
  90. REPLACE_ISINF=0; AC_SUBST([REPLACE_ISINF])
  91. REPLACE_ISNAN=0; AC_SUBST([REPLACE_ISNAN])
  92. REPLACE_LDEXPL=0; AC_SUBST([REPLACE_LDEXPL])
  93. REPLACE_NAN=0; AC_SUBST([REPLACE_NAN])
  94. REPLACE_ROUND=0; AC_SUBST([REPLACE_ROUND])
  95. REPLACE_ROUNDF=0; AC_SUBST([REPLACE_ROUNDF])
  96. REPLACE_ROUNDL=0; AC_SUBST([REPLACE_ROUNDL])
  97. REPLACE_SIGNBIT=0; AC_SUBST([REPLACE_SIGNBIT])
  98. REPLACE_SIGNBIT_USING_GCC=0; AC_SUBST([REPLACE_SIGNBIT_USING_GCC])
  99. REPLACE_TRUNCL=0; AC_SUBST([REPLACE_TRUNCL])
  100. ])