Move typecheck macros into own header
authorCampbell Barton <ideasman42@gmail.com>
Thu, 25 Sep 2014 03:05:42 +0000 (13:05 +1000)
committerCampbell Barton <ideasman42@gmail.com>
Thu, 25 Sep 2014 03:07:17 +0000 (13:07 +1000)
source/blender/blenlib/BLI_compiler_typecheck.h [new file with mode: 0644]
source/blender/blenlib/BLI_utildefines.h
source/blender/blenlib/CMakeLists.txt

diff --git a/source/blender/blenlib/BLI_compiler_typecheck.h b/source/blender/blenlib/BLI_compiler_typecheck.h
new file mode 100644 (file)
index 0000000..93dcc6e
--- /dev/null
@@ -0,0 +1,74 @@
+/*
+ * ***** BEGIN GPL LICENSE BLOCK *****
+ *
+ * This program is free software; you can redistribute it and/or
+ * modify it under the terms of the GNU General Public License
+ * as published by the Free Software Foundation; either version 2
+ * of the License, or (at your option) any later version.
+ *
+ * This program is distributed in the hope that it will be useful,
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
+ * GNU General Public License for more details.
+ *
+ * You should have received a copy of the GNU General Public License
+ * along with this program; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
+ *
+ * ***** END GPL LICENSE BLOCK *****
+ */
+
+#ifndef __BLI_COMPILER_TYPECHECK_H__
+#define __BLI_COMPILER_TYPECHECK_H__
+
+/** \file BLI_compiler_typecheck.h
+ *  \ingroup bli
+ *
+ * Type checking macros (often used to ensure valid use of macro args).
+ * These depend on compiler extensions and c11 in some cases.
+ */
+
+/* Causes warning:
+ * incompatible types when assigning to type 'Foo' from type 'Bar'
+ * ... the compiler optimizes away the temp var */
+#ifdef __GNUC__
+#define CHECK_TYPE(var, type)  {  \
+       typeof(var) *__tmp;           \
+       __tmp = (type *)NULL;         \
+       (void)__tmp;                  \
+} (void)0
+
+#define CHECK_TYPE_PAIR(var_a, var_b)  {  \
+       typeof(var_a) *__tmp;                 \
+       __tmp = (typeof(var_b) *)NULL;        \
+       (void)__tmp;                          \
+} (void)0
+
+#define CHECK_TYPE_PAIR_INLINE(var_a, var_b)  ((void)({  \
+       typeof(var_a) *__tmp;                                \
+       __tmp = (typeof(var_b) *)NULL;                       \
+       (void)__tmp;                                         \
+}))
+
+#else
+#  define CHECK_TYPE(var, type)
+#  define CHECK_TYPE_PAIR(var_a, var_b)
+#  define CHECK_TYPE_PAIR_INLINE(var_a, var_b) (void)0
+#endif
+
+/* can be used in simple macros */
+#if defined(__STDC_VERSION__) && (__STDC_VERSION__ >= 201112L)
+#  define CHECK_TYPE_INLINE(val, type) \
+       (void)((void)(((type)0) != (0 ? (val) : ((type)0))), \
+              _Generic((val), type: 0, const type: 0))
+#else
+#  define CHECK_TYPE_INLINE(val, type) \
+       ((void)(((type)0) != (0 ? (val) : ((type)0))))
+#endif
+
+#define CHECK_TYPE_NONCONST(var)  {      \
+       void *non_const = 0 ? (var) : NULL;  \
+       (void)non_const;                     \
+} (void)0
+
+#endif  /* __BLI_COMPILER_TYPECHECK_H__ */
index 5724f0e6ad46f9353098c90edbe41a7ad6c6a4fb..a829cc601062d92fc0764e32956d0ecb057b0420 100644 (file)
@@ -54,8 +54,8 @@
 #define _VA_NARGS_COUNT_MAX32(...) _VA_NARGS_EXPAND((__VA_ARGS__, \
        64, 63, 62, 61, 60, 59, 58, 57, 56, 55, 54, 53, 52, 51, 50, 49, \
        48, 47, 46, 45, 44, 43, 42, 41, 40, 39, 38, 37, 36, 35, 34, 33, \
-       32, 31, 30, 29, 28, 27, 26, 25, 24, 23, 22, 21, 20, 19, 18, 17, 16, \
-       15, 14, 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, 1, 0))
+       32, 31, 30, 29, 28, 27, 26, 25, 24, 23, 22, 21, 20, 19, 18, 17, \
+       16, 15, 14, 13, 12, 11, 10,  9,  8,  7,  6,  5,  4,  3,  2, 1, 0))
 #define _VA_NARGS_OVERLOAD_MACRO2(name, count) name##count
 #define _VA_NARGS_OVERLOAD_MACRO1(name, count) _VA_NARGS_OVERLOAD_MACRO2(name, count)
 #define _VA_NARGS_OVERLOAD_MACRO(name,  count) _VA_NARGS_OVERLOAD_MACRO1(name, count)
@@ -71,6 +71,9 @@
 #  define MAX2(x, y)          (_TYPECHECK(x, y), (((x) > (y) ? (x) : (y))))
 #endif
 
+/* include after _VA_NARGS macro */
+#include "BLI_compiler_typecheck.h"
+
 /* min/max */
 #if defined(__GNUC__) || defined(__clang__)
 
 
 /* some math and copy defines */
 
-/* Causes warning:
- * incompatible types when assigning to type 'Foo' from type 'Bar'
- * ... the compiler optimizes away the temp var */
-#ifdef __GNUC__
-#define CHECK_TYPE(var, type)  {  \
-       typeof(var) *__tmp;           \
-       __tmp = (type *)NULL;         \
-       (void)__tmp;                  \
-} (void)0
-
-#define CHECK_TYPE_PAIR(var_a, var_b)  {  \
-       typeof(var_a) *__tmp;                 \
-       __tmp = (typeof(var_b) *)NULL;        \
-       (void)__tmp;                          \
-} (void)0
-
-#define CHECK_TYPE_PAIR_INLINE(var_a, var_b)  ((void)({  \
-       typeof(var_a) *__tmp;                                \
-       __tmp = (typeof(var_b) *)NULL;                       \
-       (void)__tmp;                                         \
-}))
-
-#else
-#  define CHECK_TYPE(var, type)
-#  define CHECK_TYPE_PAIR(var_a, var_b)
-#  define CHECK_TYPE_PAIR_INLINE(var_a, var_b) (void)0
-#endif
-
-/* can be used in simple macros */
-#if defined(__STDC_VERSION__) && (__STDC_VERSION__ >= 201112L)
-#  define CHECK_TYPE_INLINE(val, type) \
-       (void)((void)(((type)0) != (0 ? (val) : ((type)0))), \
-              _Generic((val), type: 0, const type: 0))
-#else
-#  define CHECK_TYPE_INLINE(val, type) \
-       ((void)(((type)0) != (0 ? (val) : ((type)0))))
-#endif
-
-#define CHECK_TYPE_NONCONST(var)  {      \
-       void *non_const = 0 ? (var) : NULL;  \
-       (void)non_const;                     \
-} (void)0
 
 #define SWAP(type, a, b)  {    \
        type sw_ap;                \
index dd02bcf22a9024c6980aa63375c8b5206cf05e12..9efa20da13e4490f5adc43d288e812232083ca95 100644 (file)
@@ -118,6 +118,7 @@ set(SRC
        BLI_callbacks.h
        BLI_compiler_attrs.h
        BLI_compiler_compat.h
+       BLI_compiler_typecheck.h
        BLI_convexhull2d.h
        BLI_dial.h
        BLI_dlrbTree.h