Fix definition of ARRAY_SIZE for non-gcc builds
The improved ARRAY_SIZE macro uses BARF_UNLESS_AN_ARRAY which expands to a valid check for recent gcc versions and to 0 for older gcc versions but is not defined on non-gcc builds. Non-gcc builds need this macro to expand to 0 as well. The current outer test (defined(__GNUC__) && (__GNUC__ >= 3)) is a strictly weaker condition than the inner test (GIT_GNUC_PREREQ(3, 1)) so we can omit the outer test and cause the BARF_UNLESS_AN_ARRAY macro to be defined correctly on non-gcc builds as well as gcc builds with older versions. Signed-off-by: Charles Bailey <cbailey32@bloomberg.net> Signed-off-by: Junio C Hamano <gitster@pobox.com>
This commit is contained in:
parent
89c855ed3c
commit
e2c6f7cd5a
@ -58,15 +58,13 @@
|
|||||||
#define BUILD_ASSERT_OR_ZERO(cond) \
|
#define BUILD_ASSERT_OR_ZERO(cond) \
|
||||||
(sizeof(char [1 - 2*!(cond)]) - 1)
|
(sizeof(char [1 - 2*!(cond)]) - 1)
|
||||||
|
|
||||||
#if defined(__GNUC__) && (__GNUC__ >= 3)
|
#if GIT_GNUC_PREREQ(3, 1)
|
||||||
# if GIT_GNUC_PREREQ(3, 1)
|
|
||||||
/* &arr[0] degrades to a pointer: a different type from an array */
|
/* &arr[0] degrades to a pointer: a different type from an array */
|
||||||
# define BARF_UNLESS_AN_ARRAY(arr) \
|
# define BARF_UNLESS_AN_ARRAY(arr) \
|
||||||
BUILD_ASSERT_OR_ZERO(!__builtin_types_compatible_p(__typeof__(arr), \
|
BUILD_ASSERT_OR_ZERO(!__builtin_types_compatible_p(__typeof__(arr), \
|
||||||
__typeof__(&(arr)[0])))
|
__typeof__(&(arr)[0])))
|
||||||
# else
|
#else
|
||||||
# define BARF_UNLESS_AN_ARRAY(arr) 0
|
# define BARF_UNLESS_AN_ARRAY(arr) 0
|
||||||
# endif
|
|
||||||
#endif
|
#endif
|
||||||
/*
|
/*
|
||||||
* ARRAY_SIZE - get the number of elements in a visible array
|
* ARRAY_SIZE - get the number of elements in a visible array
|
||||||
|
Loading…
Reference in New Issue
Block a user