diff --git a/XAlloc.c b/XAlloc.c index 5bda74ed..5f2e9a4b 100644 --- a/XAlloc.c +++ b/XAlloc.c @@ -5,12 +5,12 @@ #ifndef _GNU_SOURCE #define _GNU_SOURCE #endif -#include #include #include #include /*{ +#include #include }*/ @@ -52,9 +52,13 @@ void* xRealloc(void* ptr, size_t size) { # define xStrdup(str_) (assert(str_), xStrdup_(str_)) #endif -#if ((__GNUC__ > 3) || (__GNUC__ == 3 && __GNUC_MINOR__ >= 3)) +#ifndef __has_attribute // Clang's macro +# define __has_attribute(x) 0 +#endif +#if (__has_attribute(nonnull) || \ + ((__GNUC__ > 3) || (__GNUC__ == 3 && __GNUC_MINOR__ >= 3))) char* xStrdup_(const char* str) __attribute__((nonnull)); -#endif // GNU C 3.3 or later +#endif // __has_attribute(nonnull) || GNU C 3.3 or later char* xStrdup_(const char* str) { char* data = strdup(str); diff --git a/XAlloc.h b/XAlloc.h index 22a6e8ab..eaebb087 100644 --- a/XAlloc.h +++ b/XAlloc.h @@ -7,6 +7,7 @@ #define _GNU_SOURCE #endif +#include #include void* xMalloc(size_t size); @@ -23,9 +24,13 @@ void* xRealloc(void* ptr, size_t size); # define xStrdup(str_) (assert(str_), xStrdup_(str_)) #endif -#if ((__GNUC__ > 3) || (__GNUC__ == 3 && __GNUC_MINOR__ >= 3)) +#ifndef __has_attribute // Clang's macro +# define __has_attribute(x) 0 +#endif +#if (__has_attribute(nonnull) || \ + ((__GNUC__ > 3) || (__GNUC__ == 3 && __GNUC_MINOR__ >= 3))) char* xStrdup_(const char* str) __attribute__((nonnull)); -#endif // GNU C 3.3 or later +#endif // __has_attribute(nonnull) || GNU C 3.3 or later char* xStrdup_(const char* str);