Hi Gary,

On 2010-11-11 I wrote:
> 2010-11-11  Bruno Haible  <br...@clisp.org>
> 
>       fcntl-h: Fix for use of C++ on glibc systems.
>       * lib/fcntl.in.h: Include <sys/stat.h> before include_next <fcntl.h>
>       also on glibc systems in C++ mode.
>       Reported by Gary V. Vaughan <g...@gnu.org>.

This fixed only half of the problem. This should now fix it for real:


2010-12-25  Bruno Haible  <br...@clisp.org>

        fcntl-h: Fix for use of C++ on glibc systems.
        * lib/fcntl.in.h: Include <sys/stat.h> before include_next <fcntl.h>
        also on glibc systems in C++ mode.
        Reported by Gary V. Vaughan <g...@gnu.org>.

--- lib/fcntl.in.h.orig Sat Dec 25 14:42:50 2010
+++ lib/fcntl.in.h      Sat Dec 25 14:41:41 2010
@@ -43,7 +43,13 @@
 #ifndef _GL_FCNTL_H
 
 #include <sys/types.h>
-#ifndef __GLIBC__ /* Avoid namespace pollution on glibc systems.  */
+/* On some systems other than glibc, <sys/stat.h> is a prerequisite of
+   <fcntl.h>.  On glibc systems, we would like to avoid namespace pollution.
+   But on glibc systems, <fcntl.h> includes <sys/stat.h> inside an
+   extern "C" { ... } block, which leads to errors in C++ mode with the
+   overridden <sys/stat.h> from gnulib.  These errors are known to be gone
+   with g++ version >= 4.3.  */
+#if !(defined __GLIBC__ || defined __UCLIBC__) || (defined __cplusplus && 
defined GNULIB_NAMESPACE && !(__GNUC__ > 4 || (__GNUC__ == 4 && __GNUC_MINOR__ 
>= 3)))
 # include <sys/stat.h>
 #endif
 /* The include_next requires a split double-inclusion guard.  */

Reply via email to