C++11 explicitly forbids macros for bool, true and false.
authorJonathan Wakely <jwakely@redhat.com>
Fri, 24 Oct 2014 20:56:40 +0000 (21:56 +0100)
committerJonathan Wakely <redi@gcc.gnu.org>
Fri, 24 Oct 2014 20:56:40 +0000 (21:56 +0100)
gcc:
* ginclude/stdbool.h: Do not define bool, true or false in C++11.

libstdc++-v3:
* testsuite/18_support/headers/cstdbool/macros.cc: New.

From-SVN: r216679

gcc/ChangeLog
gcc/ginclude/stdbool.h
libstdc++-v3/ChangeLog
libstdc++-v3/testsuite/18_support/headers/cstdbool/macros.cc [new file with mode: 0644]

index a81559adaa60809feff77a778e4307f6ad362f9e..145ce9db3d7ddeaba61e2597434df323906a8d66 100644 (file)
@@ -1,3 +1,7 @@
+2014-10-24  Jonathan Wakely  <jwakely@redhat.com>
+
+       * ginclude/stdbool.h: Do not define bool, true or false in C++11.
+
 2014-10-24  Charles Baylis  <charles.baylis@linaro.org>
 
        * config/aarch64/arm_neon.h (__LD2_LANE_FUNC): Rewrite using builtins,
index f4e802fe4d62e611614d0eef6832345086c5388d..a06f17f24600a80dc3382f8483de976321fbaf1b 100644 (file)
@@ -36,11 +36,15 @@ see the files COPYING3 and COPYING.RUNTIME respectively.  If not, see
 
 #else /* __cplusplus */
 
-/* Supporting <stdbool.h> in C++ is a GCC extension.  */
+/* Supporting _Bool in C++ is a GCC extension.  */
 #define _Bool  bool
+
+#if __cplusplus < 201103L
+/* Defining these macros in C++98 is a GCC extension.  */
 #define bool   bool
 #define false  false
 #define true   true
+#endif
 
 #endif /* __cplusplus */
 
index c2f185921f127649a69eafd8a54d5077da935a7d..27e31bb7126803bed8c20d3bea23793307227807 100644 (file)
@@ -1,3 +1,7 @@
+2014-10-24  Jonathan Wakely  <jwakely@redhat.com>
+
+       * testsuite/18_support/headers/cstdbool/macros.cc: New.
+
 2014-10-24  Paolo Carlini  <paolo.carlini@oracle.com>
 
        * include/bits/atomic_base.h: Avoid including <stdbool.h>.
diff --git a/libstdc++-v3/testsuite/18_support/headers/cstdbool/macros.cc b/libstdc++-v3/testsuite/18_support/headers/cstdbool/macros.cc
new file mode 100644 (file)
index 0000000..df2e245
--- /dev/null
@@ -0,0 +1,37 @@
+// { dg-do compile }
+// { dg-options "-std=gnu++11" }
+
+// Copyright (C) 2012 Free Software Foundation, Inc.
+//
+// This file is part of the GNU ISO C++ Library.  This library 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, or (at your option)
+// any later version.
+
+// This library 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 library; see the file COPYING3.  If not see
+// <http://www.gnu.org/licenses/>.
+
+#include <cstdbool>
+
+#ifndef __bool_true_false_are_defined
+# error "The header <cstdbool> fails to define a macro named __bool_true_false_are_defined"
+#endif
+
+#ifdef bool
+# error "The header <cstdbool> defines a macro named bool"
+#endif
+
+#ifdef true
+# error "The header <cstdbool> defines a macro named true"
+#endif
+
+#ifdef false
+# error "The header <cstdbool> defines a macro named false"
+#endif