PR c++/51588
authorjason <jason@138bc75d-0d04-0410-961f-82ee72b054a4>
Sun, 18 Dec 2011 00:55:18 +0000 (00:55 +0000)
committerjason <jason@138bc75d-0d04-0410-961f-82ee72b054a4>
Sun, 18 Dec 2011 00:55:18 +0000 (00:55 +0000)
* parser.c (cp_parser_ptr_operator): Reject pointer to member of enum.

git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@182452 138bc75d-0d04-0410-961f-82ee72b054a4

gcc/cp/ChangeLog
gcc/cp/parser.c
gcc/testsuite/ChangeLog
gcc/testsuite/g++.dg/parse/enum7.C [new file with mode: 0644]

index 4faf001..18f1dfd 100644 (file)
@@ -1,3 +1,8 @@
+2011-12-17  Jason Merrill  <jason@redhat.com>
+
+       PR c++/51588
+       * parser.c (cp_parser_ptr_operator): Reject pointer to member of enum.
+
 2011-12-17  Richard Henderson  <rth@redhat.com>
 
        PR bootstrap/51072
index ac7427e..51d04d4 100644 (file)
@@ -16448,6 +16448,9 @@ cp_parser_ptr_operator (cp_parser* parser,
 
          if (TREE_CODE (parser->scope) == NAMESPACE_DECL)
            error_at (token->location, "%qD is a namespace", parser->scope);
+         else if (TREE_CODE (parser->scope) == ENUMERAL_TYPE)
+           error_at (token->location, "cannot form pointer to member of "
+                     "non-class %q#T", parser->scope);
          else
            {
              /* The type of which the member is a member is given by the
index 066121d..235f8c9 100644 (file)
@@ -1,5 +1,8 @@
 2011-12-17  Jason Merrill  <jason@redhat.com>
 
+       PR c++/51588
+       * g++.dg/parse/enum7.C: New.
+
        PR c++/51586
        * g++.dg/lookup/nested2.C: New.
 
diff --git a/gcc/testsuite/g++.dg/parse/enum7.C b/gcc/testsuite/g++.dg/parse/enum7.C
new file mode 100644 (file)
index 0000000..d9e3a89
--- /dev/null
@@ -0,0 +1,9 @@
+// PR c++/51588
+
+enum A {};
+
+struct B : A {                 // { dg-error "" }
+  int i;
+};
+
+int A::* p = &B::i;            // { dg-error "" }