From 85ac60cfd169a48658aa5f410c48d5878aca2227 Mon Sep 17 00:00:00 2001 From: nobu Date: Fri, 3 Mar 2017 04:51:34 +0000 Subject: broken mingw * configure.in: check whether frexp and modf are broken. * include/ruby/win32.h (frexp, modf): ignore bad declarations when compiling as C++. [ruby-core:79859] [Bug #13267] git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@57762 b2dd03c8-39d4-4d8f-98ff-823fe69b080e --- configure.in | 27 +++++++++++++++++++++++++++ 1 file changed, 27 insertions(+) (limited to 'configure.in') diff --git a/configure.in b/configure.in index 92a6cc6120..9eec2e9fa2 100644 --- a/configure.in +++ b/configure.in @@ -940,6 +940,33 @@ if test "$GCC" = yes; then # various headers. Most frequent situation is the use of // # comments. We bypass ANSI C mode for them. Otherwise # extension libs cannot include those headers. + + # Since math.h in some mingw64 wrongly delcares frexp and modf + # to be pure, the variables pointed by the second arguments are + # considered uninitialized unexpectedly. + AC_CACHE_CHECK([whether frexp and modf are broken], + rb_cv_mingw64_broken_frexp_modf, + [ + save_CFLAGS="$CFLAGS" + if test "$particular_werror_flags" = "yes"; then + CFLAGS="$CFLAGS -Werror=uninitialized" + else + CFLAGS="$CFLAGS -Werror -Wuninitialized" + fi + AC_TRY_COMPILE([@%:@include + int foo(double x) + { + int exp; + frexp(x, &exp); + return exp; + }], [if (foo(0.0)) return 1;], + [rb_cv_mingw64_broken_frexp_modf=no], + [rb_cv_mingw64_broken_frexp_modf=yes]) + CFLAGS="$save_CFLAGS" + ]) + if test "$rb_cv_mingw64_broken_frexp_modf" = yes; then + AC_DEFINE(RUBY_MINGW64_BROKEN_FREXP_MODF) + fi ], [cygwin*|darwin*|netbsd*|nacl], [ # need lgamma_r(), finite() -- cgit v1.2.3