changeset 30341:6be457679ef2

ignore-value: new module * modules/ignore-value: New file. * lib/ignore-value.h: New file. * MODULES.html.sh (Compiler warning management): New section, just for this module. More to come.
author Jim Meyering <meyering@redhat.com>
date Thu, 16 Oct 2008 23:20:44 +0200
parents fe695562241f
children 4b94bb702f8b
files ChangeLog MODULES.html.sh lib/ignore-value.h modules/ignore-value
diffstat 4 files changed, 85 insertions(+), 0 deletions(-) [+]
line wrap: on
line diff
--- a/ChangeLog	Thu Oct 16 21:48:54 2008 +0200
+++ b/ChangeLog	Thu Oct 16 23:20:44 2008 +0200
@@ -1,3 +1,11 @@
+2008-10-17  Jim Meyering  <meyering@redhat.com>
+
+	ignore-value: new module
+	* modules/ignore-value: New file.
+	* lib/ignore-value.h: New file.
+	* MODULES.html.sh (Compiler warning management): New section,
+	just for this module.  More to come.
+
 2008-10-16  Paul Eggert  <eggert@cs.ucla.edu>
 
 	open-safer.c: avoid 'signed and unsigned in conditional...' warning
--- a/MODULES.html.sh	Thu Oct 16 21:48:54 2008 +0200
+++ b/MODULES.html.sh	Thu Oct 16 23:20:44 2008 +0200
@@ -1830,6 +1830,16 @@
   func_module crypto/gc-sha1
   func_end_table
 
+  element="Compiler warning management"
+  element=`printf "%s" "$element" | sed -e "$sed_lt" -e "$sed_gt"`
+  func_section_wrap ansic_ext_misc
+  func_wrap H3
+  func_echo "$element"
+
+  func_begin_table
+  func_module ignore-value
+  func_end_table
+
   element="Misc"
   element=`printf "%s" "$element" | sed -e "$sed_lt" -e "$sed_gt"`
   func_section_wrap ansic_ext_misc
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/lib/ignore-value.h	Thu Oct 16 23:20:44 2008 +0200
@@ -0,0 +1,45 @@
+/* ignore a value to quiet a compiler warning
+
+   Copyright (C) 2008 Free Software Foundation, Inc.
+
+   This program is free software: you can redistribute it and/or modify
+   it under the terms of the GNU General Public License as published by
+   the Free Software Foundation; either version 3 of the License, or
+   (at your option) any later version.
+
+   This program is distributed in the hope that it will be useful,
+   but WITHOUT ANY WARRANTY; without even the implied warranty of
+   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
+   GNU General Public License for more details.
+
+   You should have received a copy of the GNU General Public License
+   along with this program.  If not, see <http://www.gnu.org/licenses/>.  */
+
+/* Written by Jim Meyering.  */
+
+#ifndef __attribute__
+# if __GNUC__ < 2 || (__GNUC__ == 2 && __GNUC_MINOR__ < 8)
+#  define __attribute__(x)
+# endif
+#endif
+
+/* Use this function to avoid a warning when using a function declared with
+   gcc's warn_unused_result attribute, but for which you really do want to
+   ignore the result.  Traditionally, people have used a "(void)" cast to
+   indicate that a function's return value is deliberately unused.  However,
+   if the function is declared with __attribute__((warn_unused_result)),
+   gcc issues a warning even with the cast.
+
+   Caution: most of the time, you really should heed gcc's warning, and
+   check the return value.  However, in those exceptional cases in which
+   you're sure you know what you're doing, use this function.
+
+   For the record, here's one of the ignorable warnings:
+   "copy.c:233: warning: ignoring return value of 'fchown',
+   declared with attribute warn_unused_result".  */
+
+static inline void
+ignore_value (int i __attribute__ ((__unused__)))
+{
+  /* empty */
+}
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/modules/ignore-value	Thu Oct 16 23:20:44 2008 +0200
@@ -0,0 +1,22 @@
+Description:
+ignore a value to quiet a compiler warning
+
+Files:
+lib/ignore-value.h
+
+Depends-on:
+inline
+
+configure.ac:
+
+Makefile.am:
+lib_SOURCES += ignore-value.h
+
+Include:
+#include <ignore-value.h>
+
+License:
+LGPL
+
+Maintainer:
+Jim Meyering