From: Pádraig Brady Date: Fri, 7 Jan 2011 01:25:06 +0000 (+0000) Subject: ignore-value: clarify some comments X-Git-Tag: v0.1~3378 X-Git-Url: http://erislabs.net/gitweb/?p=gnulib.git;a=commitdiff_plain;h=d0270e7b630dd9c27e70ef46cc3ce5dac70dd574 ignore-value: clarify some comments * lib/ignore-value.h: Add Eric Blake as an author since he rewrote the macros. (ignore_value): Specify exactly when the GCC warn_unused_result feature became available. (ignore_ptr): Mention that ignore_value supports aggregates. --- diff --git a/ChangeLog b/ChangeLog index c3856f155..1afdc0823 100644 --- a/ChangeLog +++ b/ChangeLog @@ -1,3 +1,11 @@ +2011-01-07 Pádraig Brady + + ignore-value: fixup comments, and add Eric Blake + as an author since he rewrote the macros. + * lib/ignore-value.h (ignore_value): State that + we now support aggregates. Also specify exactly + when the GCC warn_unused_result feature was added. + 2011-01-06 Eric Blake ignore-value: support aggregate types diff --git a/lib/ignore-value.h b/lib/ignore-value.h index 52804dc23..7fd4772f0 100644 --- a/lib/ignore-value.h +++ b/lib/ignore-value.h @@ -15,7 +15,7 @@ You should have received a copy of the GNU General Public License along with this program. If not, see . */ -/* Written by Jim Meyering and Pádraig Brady. */ +/* Written by Jim Meyering, Eric Blake and Pádraig Brady. */ /* Use "ignore_value" to avoid a warning when using a function declared with gcc's warn_unused_result attribute, but for which you really do want to @@ -47,13 +47,17 @@ # endif # endif -# if __GNUC__ < 3 || (__GNUC__ == 3 && __GNUC_MINOR__ < 1) +/* The __attribute__((__warn_unused_result__)) feature + is available in gcc versions 3.4 and newer, + while the typeof feature has been available since 2.7 at least. */ +# if __GNUC__ < 3 || (__GNUC__ == 3 && __GNUC_MINOR__ < 4) # define ignore_value(x) ((void) (x)) # else # define ignore_value(x) (({ __typeof__ (x) __x = (x); (void) __x; })) # endif -/* ignore_value works for both scalars and pointers; deprecate ignore_ptr. */ +/* ignore_value works for scalars, pointers and aggregates; + deprecate ignore_ptr. */ static inline void ATTRIBUTE_DEPRECATED ignore_ptr (void *p) { (void) p; } /* deprecated: use ignore_value */