diff mbox

add test for c++/69023 - bitset whose name is used in constant-expression rejected

Message ID 567AE271.6050900@gmail.com
State New
Headers show

Commit Message

Martin Sebor Dec. 23, 2015, 6:05 p.m. UTC
Attached is a testsuite-only patch for the correct handling of
the (now resolved as invalid) c++/69023 - bitset whose name is
used in constant expression rejected.

GCC does the right thing but I didn't see the case in the PR
exercised by the test suite, so while experimenting to make sure
I understood what's going on I decided I might as well submit
the code to better test the diagnostic.

Martin

Comments

Jason Merrill Dec. 23, 2015, 8:56 p.m. UTC | #1
OK, thanks.

Jason
diff mbox

Patch

gcc/testsuite/ChangeLog:
2015-12-23  Martin Sebor  <msebor@redhat.com>

	PR c++/69023
	* g++.dg/lookup/name-clash11.C: New test.
Index: gcc/testsuite/g++.dg/lookup/name-clash11.C
===================================================================
--- gcc/testsuite/g++.dg/lookup/name-clash11.C	(revision 0)
+++ gcc/testsuite/g++.dg/lookup/name-clash11.C	(working copy)
@@ -0,0 +1,84 @@ 
+// PR c++/69023 - bitset whose name is used in constant-expression rejected
+// Test also verifies the correct evaluation of the expressions with
+// -fpermissive.
+// { dg-options "-fpermissive" }
+
+#if __cplusplus >= 201103L
+#  define ASSERT(e) static_assert (e, #e)
+#else
+#  define ASSERT(e)                                             \
+  do { struct S { bool: !!(e); } asrt; (void)&asrt; } while (0)
+#endif
+
+
+void test_bitset ()
+{
+  int x;                        // { dg-warning "changes meaning" }
+
+  {
+    struct S {
+      int x: sizeof x;          // { dg-warning "declaration" }
+    };
+  }
+}
+
+void test_enum ()
+{
+  // Also exercise (not covered by c++/69023):
+  int y;                        // { dg-warning "changes meaning" }
+  {
+    struct S {
+      enum E {
+        y = sizeof y            // { dg-warning "declaration" }
+      };
+
+      // Verify the enumerator has the correct value.
+      void test () { ASSERT (y == sizeof (int)); }
+    };
+  }
+}
+
+void test_alignas ()
+{
+  enum { A = 16 };              // { dg-warning "changes meaning" }
+  {
+    struct S {
+#if __cplusplus >= 201103L
+      alignas (A)
+#else
+      __attribute__ ((aligned (A)))
+#endif
+      int A;                    // { dg-warning "declaration" }
+
+      // Verify the member has the correct alignment.
+      void test () { ASSERT (__alignof__ (this->A) == 16); }
+    };
+  }
+}
+
+void test_array ()
+{
+  enum { A = 16 };              // { dg-warning "changes meaning" }
+  {
+    struct S {
+      int A [A];                // { dg-warning "declaration" }
+
+      // Verify the member has the correct alignment.
+      void test () { ASSERT (sizeof (this->A) == 16 * sizeof (int)); }
+    };
+  } 
+}
+
+void test_vector ()
+{
+  enum { A = 16 };              // { dg-warning "changes meaning" }
+  {
+    struct S {
+      int A __attribute__ ((vector_size (A))); // { dg-warning "declaration" }
+
+      // Verify the member has the correct size.
+      void test () { ASSERT (sizeof (this->A) == 16); }
+    };
+  } 
+}
+