|
@@ -5705,6 +5705,18 @@ clamp_double_to_int64(double number)
|
|
|
#define PROBLEMATIC_FLOAT_CONVERSION_WARNING
|
|
|
DISABLE_GCC_WARNING(float-conversion)
|
|
|
#endif
|
|
|
+
|
|
|
+
|
|
|
+ With clang 4.0 we apparently run into "double promotion" warnings here,
|
|
|
+ since clang thinks we're promoting a double to a long double.
|
|
|
+ */
|
|
|
+#if defined(__clang__)
|
|
|
+#if __has_warning("-Wdouble-promotion")
|
|
|
+#define PROBLEMATIC_DOUBLE_PROMOTION_WARNING
|
|
|
+DISABLE_GCC_WARNING(double-promotion)
|
|
|
+#endif
|
|
|
+#endif
|
|
|
+
|
|
|
|
|
|
if (isnan(number)) {
|
|
|
return 0;
|
|
@@ -5730,6 +5742,10 @@ DISABLE_GCC_WARNING(float-conversion)
|
|
|
|
|
|
|
|
|
return signbit(number) ? INT64_MIN : INT64_MAX;
|
|
|
+
|
|
|
+#ifdef PROBLEMATIC_DOUBLE_PROMOTION_WARNING
|
|
|
+ENABLE_GCC_WARNING(double-promotion)
|
|
|
+#endif
|
|
|
#ifdef PROBLEMATIC_FLOAT_CONVERSION_WARNING
|
|
|
ENABLE_GCC_WARNING(float-conversion)
|
|
|
#endif
|