aboutsummaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
authorJustin M. Keyes <justinkz@gmail.com>2019-01-20 22:40:31 +0100
committerJustin M. Keyes <justinkz@gmail.com>2019-01-20 23:51:12 +0100
commitc6a039d087ca2b333d1d3a2604d675e0010f7063 (patch)
tree594c694e2396ed96b804b7106c38db9ebf899a0d /src
parent53c0f0bba50f424683d281a3631aee86cce78368 (diff)
downloadrneovim-c6a039d087ca2b333d1d3a2604d675e0010f7063.tar.gz
rneovim-c6a039d087ca2b333d1d3a2604d675e0010f7063.tar.bz2
rneovim-c6a039d087ca2b333d1d3a2604d675e0010f7063.zip
build: Fix -Wconversion warnings for fpclassify et al
closes #8274 - Instead of #undef and re-#define, define "xfoo" wrappers to avoid include-order sensitivity. - The warnings are bogus, caused by bad interaction between glibc and clang 6+. - https://bugs.llvm.org/show_bug.cgi?id=35268 - https://bugs.llvm.org/show_bug.cgi?id=39738 - https://bugzilla.redhat.com/show_bug.cgi?id=1472437
Diffstat (limited to 'src')
-rw-r--r--src/nvim/eval/encode.c9
-rw-r--r--src/nvim/macros.h21
-rw-r--r--src/nvim/strings.c15
3 files changed, 26 insertions, 19 deletions
diff --git a/src/nvim/eval/encode.c b/src/nvim/eval/encode.c
index 64658b52d9..cf9ecd8d56 100644
--- a/src/nvim/eval/encode.c
+++ b/src/nvim/eval/encode.c
@@ -28,11 +28,6 @@
#include "nvim/lib/kvec.h"
#include "nvim/eval/typval_encode.h"
-#ifdef __MINGW32__
-# undef fpclassify
-# define fpclassify __fpclassify
-#endif
-
#define ga_concat(a, b) ga_concat(a, (char_u *)b)
#define utf_ptr2char(b) utf_ptr2char((char_u *)b)
#define utf_ptr2len(b) ((size_t)utf_ptr2len((char_u *)b))
@@ -327,7 +322,7 @@ int encode_read_from_list(ListReaderState *const state, char *const buf,
#define TYPVAL_ENCODE_CONV_FLOAT(tv, flt) \
do { \
const float_T flt_ = (flt); \
- switch (fpclassify(flt_)) { \
+ switch (xfpclassify(flt_)) { \
case FP_NAN: { \
ga_concat(gap, (char_u *) "str2float('nan')"); \
break; \
@@ -531,7 +526,7 @@ int encode_read_from_list(ListReaderState *const state, char *const buf,
#define TYPVAL_ENCODE_CONV_FLOAT(tv, flt) \
do { \
const float_T flt_ = (flt); \
- switch (fpclassify(flt_)) { \
+ switch (xfpclassify(flt_)) { \
case FP_NAN: { \
EMSG(_("E474: Unable to represent NaN value in JSON")); \
return FAIL; \
diff --git a/src/nvim/macros.h b/src/nvim/macros.h
index d447bff765..1d47520d8a 100644
--- a/src/nvim/macros.h
+++ b/src/nvim/macros.h
@@ -1,6 +1,10 @@
#ifndef NVIM_MACROS_H
#define NVIM_MACROS_H
+#include <math.h>
+
+#include "auto/config.h"
+
// EXTERN is only defined in main.c. That's where global variables are
// actually defined and initialized.
#ifndef EXTERN
@@ -19,6 +23,23 @@
# define MAX(X, Y) ((X) > (Y) ? (X) : (Y))
#endif
+#if defined(__clang__) && __clang__ == 1 && __clang_major__ >= 6 \
+ && defined(HAVE___FPCLASSIFY)
+// Workaround glibc + Clang 6+ bug. #8274
+// https://bugzilla.redhat.com/show_bug.cgi?id=1472437
+# define xfpclassify __fpclassify
+# define xisnan __isnan
+# define xisinf __isinf
+#elif defined(__MINGW32__)
+// Workaround mingw warning. #7863
+# define xfpclassify __fpclassify
+# define xisnan _isnan
+#else
+# define xfpclassify fpclassify
+# define xisnan isnan
+# define xisinf isinf
+#endif
+
/// String with length
///
/// For use in functions which accept (char *s, size_t len) pair in arguments.
diff --git a/src/nvim/strings.c b/src/nvim/strings.c
index 4921824316..533784767c 100644
--- a/src/nvim/strings.c
+++ b/src/nvim/strings.c
@@ -50,16 +50,7 @@
#include "nvim/os/shell.h"
#include "nvim/eval/encode.h"
-#ifdef __MINGW32__
-# undef fpclassify
-# define fpclassify __fpclassify
-# undef isnan
-# define isnan _isnan
-#endif
-
-/*
- * Copy "string" into newly allocated memory.
- */
+/// Copy "string" into newly allocated memory.
char_u *vim_strsave(const char_u *string)
FUNC_ATTR_NONNULL_RET FUNC_ATTR_MALLOC FUNC_ATTR_NONNULL_ALL
{
@@ -1214,14 +1205,14 @@ int vim_vsnprintf(char *str, size_t str_m, const char *fmt, va_list ap,
remove_trailing_zeroes = true;
}
- if (isinf(f)
+ if (xisinf(f)
|| (strchr("fF", fmt_spec) != NULL && abs_f > 1.0e307)) {
xstrlcpy(tmp, infinity_str(f > 0.0, fmt_spec,
force_sign, space_for_positive),
sizeof(tmp));
str_arg_l = strlen(tmp);
zero_padding = 0;
- } else if (isnan(f)) {
+ } else if (xisnan(f)) {
// Not a number: nan or NAN
memmove(tmp, ASCII_ISUPPER(fmt_spec) ? "NAN" : "nan", 4);
str_arg_l = 3;