diff options
author | Jim Meyering <jim@meyering.net> | 2005-07-04 13:56:18 +0000 |
---|---|---|
committer | Jim Meyering <jim@meyering.net> | 2005-07-04 13:56:18 +0000 |
commit | fbdee4c72020dfb779a5b941b647a70c310dd68d (patch) | |
tree | ee8c3ad26e9aecc1171f19a69f177eb014174759 | |
parent | 9a00b08ea686775485dc122aba0871006960e8dd (diff) | |
download | coreutils-fbdee4c72020dfb779a5b941b647a70c310dd68d.tar.xz |
(verify): Rename from VERIFY_EXPR, to be lower case,
like assert. Use sizeof, rather than equivalent ((...)0), for
it's slightly simpler syntax. Suggestions from Paul Eggert.
(verify_decl): Rename from VERIFY.
-rw-r--r-- | src/system.h | 39 |
1 files changed, 23 insertions, 16 deletions
diff --git a/src/system.h b/src/system.h index cb6158f0b..cef4fc9ed 100644 --- a/src/system.h +++ b/src/system.h @@ -806,27 +806,34 @@ ptr_align (void const *ptr, size_t alignment) return (void *) (p1 - (size_t) p1 % alignment); } -#ifndef VERIFY +#ifndef verify_dcl # define GL_CONCAT0(x, y) x##y # define GL_CONCAT(x, y) GL_CONCAT0 (x, y) -/* Verify a requirement at compile-time (unlike assert, which is runtime). */ -# define VERIFY(assertion) \ - struct GL_CONCAT (compile_time_assert_, __LINE__) \ - { char a[(assertion) ? 1 : -1]; } -#endif - -/* Like the above, but use an expression rather than a struct declaration. - This macro may be used in some contexts where the other may not. */ -#undef VERIFY_EXPR -#define VERIFY_EXPR(assertion) \ - (void)((struct {char a[(assertion) ? 1 : -1]; } *) 0) -/* Use the compile-time type-max. assertion only if the compiler provides - the __typeof__ operator. */ +/* Verify requirement, R, at compile-time, as a declaration. + The implementation uses a struct declaration whose name includes the + expansion of __LINE__, so there is a small chance that two uses of + verify_dcl from different files will end up colliding (for example, + f.c includes f.h and verify_dcl is used on the same line in each). */ +# define verify_dcl(R) \ + struct GL_CONCAT (ct_assert_, __LINE__) { char a[(R) ? 1 : -1]; } +#endif + +/* Verify requirement, R, at compile-time, as an expression. + Unlike assert, there is no run-time overhead. Unlike verify_dcl, + above, there is no risk of collision, since there is no declared name. + This macro may be used in some contexts where the other may not. + Return void. */ +#undef verify +#define verify(R) ((void) sizeof (struct { char a[(R) ? 1 : -1]; })) + +/* With a compiler that supports the __typeof__ operator, ensure that + TYPEOF_REQUIREMENT is nonzero at compile time. If the compiler does + not support __typeof__, do nothing. */ #if HAVE_TYPEOF -# define VERIFY_W_TYPEOF(assertion) VERIFY_EXPR (assertion) +# define VERIFY_W_TYPEOF(typeof_requirement) verify (typeof_requirement) #else -# define VERIFY_W_TYPEOF(assertion) ((void) 0) +# define VERIFY_W_TYPEOF(typeof_requirement) ((void) 0) #endif /* If 10*Accum+Digit_val is larger than Type_max, then don't update Accum |