Ensure that <features.h> is included before __GLIBC__ is tested.
authorBruno Haible <bruno@clisp.org>
Sat, 20 Nov 2010 22:46:16 +0000 (23:46 +0100)
committerBruno Haible <bruno@clisp.org>
Sat, 20 Nov 2010 22:46:16 +0000 (23:46 +0100)
* lib/printf-parse.h: Include <features.h>.
* m4/vasnprintf.m4 (gl_PREREQ_PRINTF_PARSE): Require gl_FEATURES_H.

* lib/wchar.in.h: Include <features.h>.
* m4/wchar_h.m4 (gl_WCHAR_H): Require gl_FEATURES_H.
* modules/wchar (Makefile.am): Substitute HAVE_FEATURES_H.

* lib/arpa_inet.in.h: Include <features.h>.
* m4/arpa_inet_h.m4 (gl_HEADER_ARPA_INET): Require gl_FEATURES_H.
* modules/arpa_inet (Makefile.am): Substitute HAVE_FEATURES_H.

* build-aux/link-warning.h: Include <features.h>.
* modules/link-warning (configure.ac): Require gl_FEATURES_H.
(Makefile.am): Substitute HAVE_FEATURES_H into link-warning.h.

* m4/gnulib-common.m4 (gl_FEATURES_H): New macro.
Reported by Mike Frysinger <vapier@gentoo.org>.

12 files changed:
ChangeLog
build-aux/link-warning.h
lib/arpa_inet.in.h
lib/printf-parse.h
lib/wchar.in.h
m4/arpa_inet_h.m4
m4/gnulib-common.m4
m4/vasnprintf.m4
m4/wchar_h.m4
modules/arpa_inet
modules/link-warning
modules/wchar

index 6770d43f600a908d6b85f08eff6f39154edc70e7..c9c1e9cdd5c763ff533f7ba4af40a57d6902185e 100644 (file)
--- a/ChangeLog
+++ b/ChangeLog
@@ -1,3 +1,32 @@
+2010-11-20  Bruno Haible  <bruno@clisp.org>
+
+       Ensure that <features.h> is included before __GLIBC__ is tested.
+       * lib/printf-parse.h: Include <features.h>.
+       * m4/vasnprintf.m4 (gl_PREREQ_PRINTF_PARSE): Require gl_FEATURES_H.
+       Reported by Mike Frysinger <vapier@gentoo.org>.
+
+       Ensure that <features.h> is included before __GLIBC__ is tested.
+       * lib/wchar.in.h: Include <features.h>.
+       * m4/wchar_h.m4 (gl_WCHAR_H): Require gl_FEATURES_H.
+       * modules/wchar (Makefile.am): Substitute HAVE_FEATURES_H.
+       Reported by Mike Frysinger <vapier@gentoo.org>.
+
+       Ensure that <features.h> is included before __GLIBC__ is tested.
+       * lib/arpa_inet.in.h: Include <features.h>.
+       * m4/arpa_inet_h.m4 (gl_HEADER_ARPA_INET): Require gl_FEATURES_H.
+       * modules/arpa_inet (Makefile.am): Substitute HAVE_FEATURES_H.
+       Reported by Mike Frysinger <vapier@gentoo.org>.
+
+       Ensure that <features.h> is included before __GLIBC__ is tested.
+       * build-aux/link-warning.h: Include <features.h>.
+       * modules/link-warning (configure.ac): Require gl_FEATURES_H.
+       (Makefile.am): Substitute HAVE_FEATURES_H into link-warning.h.
+       Reported by Mike Frysinger <vapier@gentoo.org>.
+
+       Ensure that <features.h> is included before __GLIBC__ is tested.
+       * m4/gnulib-common.m4 (gl_FEATURES_H): New macro.
+       Reported by Mike Frysinger <vapier@gentoo.org>.
+
 2010-11-20  Bruno Haible  <bruno@clisp.org>
 
        memmem: Fix autoconf test.
index cd01b50e9e769d9d1124461419e228c136127360..27abfd95a69a6bf8a41c49fb8944341e38edf869 100644 (file)
    You should have received a copy of the GNU Lesser General Public License
    along with this program.  If not, see <http://www.gnu.org/licenses/>.  */
 
+#if @HAVE_FEATURES_H@
+# include <features.h> /* for __GLIBC__, __UCLIBC__ */
+#endif
+
 /* GL_LINK_WARNING("literal string") arranges to emit the literal string as
    a linker warning on most glibc systems.
    We use a linker warning rather than a preprocessor warning, because
index 2932f8ef503647ce2b63dc962e79a8dc42378456..fbf084252f6a7afd5db0bdff52fc25b9aeed37dd 100644 (file)
 #endif
 @PRAGMA_COLUMNS@
 
+#if @HAVE_FEATURES_H@
+# include <features.h> /* for __GLIBC__ */
+#endif
+
 /* Gnulib's sys/socket.h is responsible for pulling in winsock2.h etc
    under MinGW.
    But avoid namespace pollution on glibc systems.  */
index 6bd11dfa1a5f9fbacc0ab3b751087863c6279fac..eb5480b68a7ceebab73bd3a537d121a7d7305314 100644 (file)
      ENABLE_UNISTDIO    Set to 1 to enable the unistdio extensions.
      STATIC             Set to 'static' to declare the function static.  */
 
+#if HAVE_FEATURES_H
+# include <features.h> /* for __GLIBC__, __UCLIBC__ */
+#endif
+
 #include "printf-args.h"
 
 
index 3b57f00347f73a4f82453708468d11ddc75d7ee7..a38026ca993dfd61fd817509b6412fada9769d9b 100644 (file)
 
 #define _GL_ALREADY_INCLUDING_WCHAR_H
 
+#if @HAVE_FEATURES_H@
+# include <features.h> /* for __GLIBC__ */
+#endif
+
 /* Tru64 with Desktop Toolkit C has a bug: <stdio.h> must be included before
    <wchar.h>.
    BSD/OS 4.0.1 has a bug: <stddef.h>, <stdio.h> and <time.h> must be
index 490a005ad96d2fb3a47d89b0e02a21be9b548a8c..80fdb406b637ab22e3e3eeac87351e85dc704006 100644 (file)
@@ -1,4 +1,4 @@
-# arpa_inet_h.m4 serial 9
+# arpa_inet_h.m4 serial 10
 dnl Copyright (C) 2006, 2008-2010 Free Software Foundation, Inc.
 dnl This file is free software; the Free Software Foundation
 dnl gives unlimited permission to copy and/or distribute it,
@@ -22,6 +22,8 @@ AC_DEFUN([gl_HEADER_ARPA_INET],
   dnl <arpa/inet.h> is always overridden, because of GNULIB_POSIXCHECK.
   gl_CHECK_NEXT_HEADERS([arpa/inet.h])
 
+  AC_REQUIRE([gl_FEATURES_H])
+
   dnl Check for declarations of anything we want to poison if the
   dnl corresponding gnulib module is not in use.
   gl_WARN_ON_USE_PREPARE([[
index 4c7ac30d0fac314cfa28fc9788ef33917d234ad7..d0c8b66287d768f1b2d98acf7c60da2ccff07695 100644 (file)
@@ -1,4 +1,4 @@
-# gnulib-common.m4 serial 20
+# gnulib-common.m4 serial 21
 dnl Copyright (C) 2007-2010 Free Software Foundation, Inc.
 dnl This file is free software; the Free Software Foundation
 dnl gives unlimited permission to copy and/or distribute it,
@@ -102,6 +102,19 @@ AC_DEFUN([gl_MODULE_INDICATOR_FOR_TESTS],
     [Define to 1 when the gnulib module $1 should be tested.])
 ])
 
+# Test whether <features.h> exists.
+# Set HAVE_FEATURES_H.
+AC_DEFUN([gl_FEATURES_H],
+[
+  AC_CHECK_HEADERS_ONCE([features.h])
+  if test $ac_cv_header_features_h = yes; then
+    HAVE_FEATURES_H=1
+  else
+    HAVE_FEATURES_H=0
+  fi
+  AC_SUBST([HAVE_FEATURES_H])
+])
+
 # m4_foreach_w
 # is a backport of autoconf-2.59c's m4_foreach_w.
 # Remove this macro when we can assume autoconf >= 2.60.
index ebe3c52cde6f5b745f77da016e967642620d2fa0..9c045202425d7f7814df3416f2ac6d52f5697e6b 100644 (file)
@@ -1,4 +1,4 @@
-# vasnprintf.m4 serial 31
+# vasnprintf.m4 serial 32
 dnl Copyright (C) 2002-2004, 2006-2010 Free Software Foundation, Inc.
 dnl This file is free software; the Free Software Foundation
 dnl gives unlimited permission to copy and/or distribute it,
@@ -40,6 +40,7 @@ AC_DEFUN([gl_PREREQ_PRINTF_ARGS],
 # Prequisites of lib/printf-parse.h, lib/printf-parse.c.
 AC_DEFUN([gl_PREREQ_PRINTF_PARSE],
 [
+  AC_REQUIRE([gl_FEATURES_H])
   AC_REQUIRE([AC_TYPE_LONG_LONG_INT])
   AC_REQUIRE([gt_TYPE_WCHAR_T])
   AC_REQUIRE([gt_TYPE_WINT_T])
index c1fc304889078881ec384a0b72aadab48cce38bc..8c8fad96df6c5d0fbddb2bd655237b9bb5b8d65d 100644 (file)
@@ -7,7 +7,7 @@ dnl with or without modifications, as long as this notice is preserved.
 
 dnl Written by Eric Blake.
 
-# wchar_h.m4 serial 34
+# wchar_h.m4 serial 35
 
 AC_DEFUN([gl_WCHAR_H],
 [
@@ -26,6 +26,8 @@ AC_DEFUN([gl_WCHAR_H],
   fi
   AC_SUBST([HAVE_WCHAR_H])
 
+  AC_REQUIRE([gl_FEATURES_H])
+
   AC_REQUIRE([gt_TYPE_WINT_T])
   if test $gt_cv_c_wint_t = yes; then
     HAVE_WINT_T=1
index d75187380938606457570ec8a5277a625fb47386..cec5d6c854a6eb42cc8c942f7beb1ccb0a40368b 100644 (file)
@@ -27,6 +27,7 @@ arpa/inet.h: arpa_inet.in.h $(WARN_ON_USE_H) $(ARG_NONNULL_H)
          sed -e 's|@''INCLUDE_NEXT''@|$(INCLUDE_NEXT)|g' \
              -e 's|@''PRAGMA_SYSTEM_HEADER''@|@PRAGMA_SYSTEM_HEADER@|g' \
              -e 's|@''PRAGMA_COLUMNS''@|@PRAGMA_COLUMNS@|g' \
+             -e 's|@''HAVE_FEATURES_H''@|$(HAVE_FEATURES_H)|g' \
              -e 's|@''NEXT_ARPA_INET_H''@|$(NEXT_ARPA_INET_H)|g' \
              -e 's|@''HAVE_ARPA_INET_H''@|$(HAVE_ARPA_INET_H)|g' \
              -e 's|@''GNULIB_INET_NTOP''@|$(GNULIB_INET_NTOP)|g' \
index 935f66a39052ef766e57c6dfd1cda66847a49783..06f3675cb1bd81d86448ca9c7f979020759a55d9 100644 (file)
@@ -10,6 +10,7 @@ build-aux/link-warning.h
 Depends-on:
 
 configure.ac:
+AC_REQUIRE([gl_FEATURES_H])
 
 Makefile.am:
 # The BUILT_SOURCES created by this Makefile snippet are not used via #include
@@ -22,8 +23,9 @@ BUILT_SOURCES += link-warning.h
 # build-aux/link-warning.h, except that it has the copyright header cut off.
 link-warning.h: $(top_srcdir)/build-aux/link-warning.h
        $(AM_V_GEN)rm -f $@-t $@ && \
-       sed -n -e '/GL_LINK_WARNING/,$$p' \
+       sed -n -e '/HAVE_FEATURES_H/,$$p' \
          < $(top_srcdir)/build-aux/link-warning.h \
+       | sed -e 's|@''HAVE_FEATURES_H''@|$(HAVE_FEATURES_H)|g' \
          > $@-t && \
        mv $@-t $@
 MOSTLYCLEANFILES += link-warning.h link-warning.h-t
index c9d5c46c3cd44efc5d3f995ca38de6c1af62047a..f67737d9d6d94ffb145586d1eee85106e84b7e31 100644 (file)
@@ -27,6 +27,7 @@ wchar.h: wchar.in.h $(CXXDEFS_H) $(ARG_NONNULL_H) $(WARN_ON_USE_H)
          sed -e 's|@''INCLUDE_NEXT''@|$(INCLUDE_NEXT)|g' \
              -e 's|@''PRAGMA_SYSTEM_HEADER''@|@PRAGMA_SYSTEM_HEADER@|g' \
              -e 's|@''PRAGMA_COLUMNS''@|@PRAGMA_COLUMNS@|g' \
+             -e 's|@''HAVE_FEATURES_H''@|$(HAVE_FEATURES_H)|g' \
              -e 's|@''NEXT_WCHAR_H''@|$(NEXT_WCHAR_H)|g' \
              -e 's|@''HAVE_WCHAR_H''@|$(HAVE_WCHAR_H)|g' \
              -e 's|@''GNULIB_BTOWC''@|$(GNULIB_BTOWC)|g' \