]> granicus.if.org Git - clang/commitdiff
Set a member's access specifier even if it doesn't match the previous specifier.
authorJohn McCall <rjmccall@apple.com>
Wed, 23 Dec 2009 00:37:40 +0000 (00:37 +0000)
committerJohn McCall <rjmccall@apple.com>
Wed, 23 Dec 2009 00:37:40 +0000 (00:37 +0000)
Prevents an assert on successive redeclarations.

Fixed PR5573.

git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@91956 91177308-0d34-0410-b5e6-96231b3b80d8

lib/Sema/SemaAccess.cpp
test/SemaCXX/access.cpp

index 21f83a560d7c4b8792ac47219d2bc0ab9156eea5..b7cc37b6c9a76e0dfd839d2b8d1b20cce3f24370 100644 (file)
@@ -37,6 +37,8 @@ bool Sema::SetMemberAccessSpecifier(NamedDecl *MemberDecl,
       << MemberDecl << LexicalAS;
     Diag(PrevMemberDecl->getLocation(), diag::note_previous_access_declaration)
       << PrevMemberDecl << PrevMemberDecl->getAccess();
+
+    MemberDecl->setAccess(LexicalAS);
     return true;
   }
 
index ae2fef11f81fb12db8702cf46ee7ade360819537..6115ff6a94f405a2d55bcfb7172f9fb110cb81c5 100644 (file)
@@ -21,3 +21,14 @@ protected:
 private:
     template<typename T> struct A {}; // expected-error {{'A' redeclared with 'private' access}}
 };
+
+// PR5573
+namespace test1 {
+  class A {
+  private:
+    class X; // expected-note {{previously declared 'private' here}}
+  public:
+    class X; // expected-error {{ 'X' redeclared with 'public' access}}
+    class X {};
+  };
+}