aboutsummaryrefslogtreecommitdiff
path: root/src/common
diff options
context:
space:
mode:
authorNick Mathewson <nickm@torproject.org>2017-07-05 16:10:45 -0400
committerNick Mathewson <nickm@torproject.org>2017-07-05 16:10:45 -0400
commitdfc06148407a1610d515d45b344558850486bd98 (patch)
tree1d4b5de54bbb0c8b1ba9ef1c3dc979d2a309ab19 /src/common
parent32c0066e4baa2ca16902a70b941d8d3afbc279ff (diff)
downloadtor-dfc06148407a1610d515d45b344558850486bd98.tar.gz
tor-dfc06148407a1610d515d45b344558850486bd98.zip
Only disable -Wfloat-conversion on mingw when it exists.
The 22081 fix disabled -Wfloat-conversion, but -Wfloat-conversion didn't exist in every relevant mingw; it was added in GCC 4.9.x some time, if the documentation can be trusted. Bug not in any released version of tor.
Diffstat (limited to 'src/common')
-rw-r--r--src/common/util.c5
1 files changed, 3 insertions, 2 deletions
diff --git a/src/common/util.c b/src/common/util.c
index b7468dfcb3..9e61eb7710 100644
--- a/src/common/util.c
+++ b/src/common/util.c
@@ -5695,13 +5695,14 @@ clamp_double_to_int64(double number)
{
int exponent;
-#if defined(__MINGW32__) || defined(__MINGW64__)
+#if (defined(__MINGW32__) || defined(__MINGW64__)) && GCC_VERSION >= 409
/*
Mingw's math.h uses gcc's __builtin_choose_expr() facility to declare
isnan, isfinite, and signbit. But as implemented in at least some
versions of gcc, __builtin_choose_expr() can generate type warnings
even from branches that are not taken. So, suppress those warnings.
*/
+#define PROBLEMATIC_FLOAT_CONVERSION_WARNING
DISABLE_GCC_WARNING(float-conversion)
#endif
/* NaN is a special case that can't be used with the logic below. */
@@ -5729,7 +5730,7 @@ DISABLE_GCC_WARNING(float-conversion)
/* Handle infinities and finite numbers with magnitude >= 2^63. */
return signbit(number) ? INT64_MIN : INT64_MAX;
-#if defined(__MINGW32__) || defined(__MINGW64__)
+#ifdef PROBLEMATIC_FLOAT_CONVERSION_WARNING
ENABLE_GCC_WARNING(float-conversion)
#endif
}