diff options
| author | John McCall <rjmccall@apple.com> | 2009-12-23 00:37:40 +0000 |
|---|---|---|
| committer | John McCall <rjmccall@apple.com> | 2009-12-23 00:37:40 +0000 |
| commit | 0a4bb26ed03dc36ebbc68b1e5da498ddc8ba4f3c (patch) | |
| tree | c5928e1251396cc69e647db9ae960ac03237c97f /clang | |
| parent | 31e39bd3d47cbfa6d2c99ee1ad7bdabbc648117d (diff) | |
| download | bcm5719-llvm-0a4bb26ed03dc36ebbc68b1e5da498ddc8ba4f3c.tar.gz bcm5719-llvm-0a4bb26ed03dc36ebbc68b1e5da498ddc8ba4f3c.zip | |
Set a member's access specifier even if it doesn't match the previous specifier.
Prevents an assert on successive redeclarations.
Fixed PR5573.
llvm-svn: 91956
Diffstat (limited to 'clang')
| -rw-r--r-- | clang/lib/Sema/SemaAccess.cpp | 2 | ||||
| -rw-r--r-- | clang/test/SemaCXX/access.cpp | 11 |
2 files changed, 13 insertions, 0 deletions
diff --git a/clang/lib/Sema/SemaAccess.cpp b/clang/lib/Sema/SemaAccess.cpp index 21f83a560d7..b7cc37b6c9a 100644 --- a/clang/lib/Sema/SemaAccess.cpp +++ b/clang/lib/Sema/SemaAccess.cpp @@ -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; } diff --git a/clang/test/SemaCXX/access.cpp b/clang/test/SemaCXX/access.cpp index ae2fef11f81..6115ff6a94f 100644 --- a/clang/test/SemaCXX/access.cpp +++ b/clang/test/SemaCXX/access.cpp @@ -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 {}; + }; +} |

