diff options
author | John McCall <rjmccall@apple.com> | 2010-02-02 08:45:54 +0000 |
---|---|---|
committer | John McCall <rjmccall@apple.com> | 2010-02-02 08:45:54 +0000 |
commit | 4f9506a27cb6b865bf38beea48eadfa9dc93f510 (patch) | |
tree | 74f14cf5d626982070d697032e4be5eb8a510cd6 /lib/Sema/SemaAccess.cpp | |
parent | fb8b69aef3377aaa786d1278aaae7e7b04ac095f (diff) |
Access control for implicit destructor calls. Diagnostic could be orders of
magnitude clearer.
git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@95078 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'lib/Sema/SemaAccess.cpp')
-rw-r--r-- | lib/Sema/SemaAccess.cpp | 25 |
1 files changed, 25 insertions, 0 deletions
diff --git a/lib/Sema/SemaAccess.cpp b/lib/Sema/SemaAccess.cpp index ceee61df23..98beb610a5 100644 --- a/lib/Sema/SemaAccess.cpp +++ b/lib/Sema/SemaAccess.cpp @@ -306,6 +306,31 @@ bool Sema::CheckUnresolvedMemberAccess(UnresolvedMemberExpr *E, return false; } +bool Sema::CheckDestructorAccess(SourceLocation Loc, + QualType T) { + if (!getLangOptions().AccessControl) + return false; + + const RecordType *Record = T->getAs<RecordType>(); + if (!Record) + return false; + + CXXRecordDecl *NamingClass = cast<CXXRecordDecl>(Record->getDecl()); + CXXDestructorDecl *Dtor = NamingClass->getDestructor(Context); + + AccessSpecifier Access = Dtor->getAccess(); + if (Access == AS_public) + return false; + + LookupResult R(*this, Dtor->getDeclName(), Loc, LookupOrdinaryName); + R.suppressDiagnostics(); + + R.setNamingClass(NamingClass); + return CheckAccess(R, Dtor, Access); + + // FIXME: protected check +} + /// Checks access to a constructor. bool Sema::CheckConstructorAccess(SourceLocation UseLoc, CXXConstructorDecl *Constructor, |