aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorDavid Robillard <d@drobilla.net>2019-01-07 20:04:08 +0100
committerDavid Robillard <d@drobilla.net>2019-04-13 19:48:23 +0200
commit00cb5c4f38b36ed3daa074ecdfffcd4676b11468 (patch)
tree7acbe576c866a94364d5e5ee343a1d2528590f35
parentcec24f4b4d270093065141e68ddc0fa2b88b2454 (diff)
downloadserd-00cb5c4f38b36ed3daa074ecdfffcd4676b11468.tar.gz
serd-00cb5c4f38b36ed3daa074ecdfffcd4676b11468.tar.bz2
serd-00cb5c4f38b36ed3daa074ecdfffcd4676b11468.zip
Suppress spurious floating point conversion warning
This is defined by the standard to work with floating point expressions, the warning is a quirk of glibc.
-rw-r--r--src/node.c14
-rw-r--r--src/warnings.h38
2 files changed, 42 insertions, 10 deletions
diff --git a/src/node.c b/src/node.c
index a7cb56b2..c726a2db 100644
--- a/src/node.c
+++ b/src/node.c
@@ -18,6 +18,7 @@
#include "serd_internal.h"
#include "string_utils.h"
+#include "warnings.h"
#include <assert.h>
#include <float.h>
@@ -28,15 +29,6 @@
#include <stdlib.h>
#include <string.h>
-#ifdef _WIN32
-# ifndef isnan
-# define isnan(x) _isnan(x)
-# endif
-# ifndef isinf
-# define isinf(x) (!_finite(x))
-# endif
-#endif
-
static const size_t serd_node_align = sizeof(SerdNode);
typedef struct StaticNode {
@@ -527,9 +519,11 @@ serd_digits(double abs)
SerdNode*
serd_new_decimal(double d, unsigned frac_digits, const SerdNode* datatype)
{
- if (isnan(d) || isinf(d)) {
+ SERD_DISABLE_CONVERSION_WARNINGS
+ if (!isfinite(d)) {
return NULL;
}
+ SERD_RESTORE_WARNINGS
const SerdNode* type = datatype ? datatype : &serd_xsd_decimal.node;
const double abs_d = fabs(d);
diff --git a/src/warnings.h b/src/warnings.h
new file mode 100644
index 00000000..9886dc75
--- /dev/null
+++ b/src/warnings.h
@@ -0,0 +1,38 @@
+/*
+ Copyright 2019 David Robillard <http://drobilla.net>
+
+ Permission to use, copy, modify, and/or distribute this software for any
+ purpose with or without fee is hereby granted, provided that the above
+ copyright notice and this permission notice appear in all copies.
+
+ THIS SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
+ WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
+ MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
+ ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
+ WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
+ ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
+ OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
+*/
+
+#if defined(__clang__)
+#define SERD_DISABLE_CONVERSION_WARNINGS \
+ _Pragma("clang diagnostic push") \
+ _Pragma("clang diagnostic ignored \"-Wconversion\"")
+ _Pragma("clang diagnostic ignored \"-Wdouble-promotion\"")
+#elif defined(__GNUC__)
+#define SERD_DISABLE_CONVERSION_WARNINGS \
+ _Pragma("GCC diagnostic push") \
+ _Pragma("GCC diagnostic ignored \"-Wconversion\"")
+ _Pragma("GCC diagnostic ignored \"-Wdouble-promotion\"")
+#else
+#define SERD_DISABLE_CONVERSION_WARNINGS
+#endif
+
+#if defined(__clang__)
+#define SERD_RESTORE_WARNINGS _Pragma("clang diagnostic pop")
+#elif defined(__GNUC__)
+#define SERD_RESTORE_WARNINGS _Pragma("GCC diagnostic pop")
+#else
+#define SERD_RESTORE_WARNINGS
+#endif
+