From 7d34f4e5c5cedc373f8b3c20dc18cd0c75af4da7 Mon Sep 17 00:00:00 2001 From: Ivan Maidanski Date: Thu, 23 Mar 2017 11:24:06 +0300 Subject: [PATCH] Use C11 static_assert if available (code refactoring) * include/private/gc_priv.h [static_assert && __STDC_VERSION__>=201112] (GC_STATIC_ASSERT): Define to static_assert (with an empty message); update comment. --- include/private/gc_priv.h | 8 +++++--- 1 file changed, 5 insertions(+), 3 deletions(-) diff --git a/include/private/gc_priv.h b/include/private/gc_priv.h index 2c7e787a..f7a0a714 100644 --- a/include/private/gc_priv.h +++ b/include/private/gc_priv.h @@ -2420,14 +2420,16 @@ GC_INNER ptr_t GC_store_debug_info(ptr_t p, word sz, const char *str, # define GC_ASSERT(expr) #endif -/* Check a compile time assertion at compile time. The error */ -/* message for failure is a bit baroque, but ... */ -#if defined(mips) && !defined(__GNUC__) +/* Check a compile time assertion at compile time. */ +#if defined(static_assert) && (__STDC_VERSION__ >= 201112L) +# define GC_STATIC_ASSERT(expr) static_assert(expr, "") +#elif defined(mips) && !defined(__GNUC__) /* DOB: MIPSPro C gets an internal error taking the sizeof an array type. This code works correctly (ugliness is to avoid "unused var" warnings) */ # define GC_STATIC_ASSERT(expr) \ do { if (0) { char j[(expr)? 1 : -1]; j[0]='\0'; j[0]=j[0]; } } while(0) #else + /* The error message for failure is a bit baroque, but ... */ # define GC_STATIC_ASSERT(expr) (void)sizeof(char[(expr)? 1 : -1]) #endif -- 2.40.0