summaryrefslogtreecommitdiffstats
path: root/clang/lib/Sema/SemaAccess.cpp
diff options
context:
space:
mode:
authorJohn McCall <rjmccall@apple.com>2010-02-02 08:45:54 +0000
committerJohn McCall <rjmccall@apple.com>2010-02-02 08:45:54 +0000
commit6781b05a9254f3aaf53126368d23ebda88e02c96 (patch)
tree7b7339acf055272e9d06327b8b5c40a167669ce9 /clang/lib/Sema/SemaAccess.cpp
parent49786a6c31ae410b9bca94699bb3b70088c9f147 (diff)
downloadbcm5719-llvm-6781b05a9254f3aaf53126368d23ebda88e02c96.tar.gz
bcm5719-llvm-6781b05a9254f3aaf53126368d23ebda88e02c96.zip
Access control for implicit destructor calls. Diagnostic could be orders of
magnitude clearer. llvm-svn: 95078
Diffstat (limited to 'clang/lib/Sema/SemaAccess.cpp')
-rw-r--r--clang/lib/Sema/SemaAccess.cpp25
1 files changed, 25 insertions, 0 deletions
diff --git a/clang/lib/Sema/SemaAccess.cpp b/clang/lib/Sema/SemaAccess.cpp
index ceee61df23a..98beb610a5e 100644
--- a/clang/lib/Sema/SemaAccess.cpp
+++ b/clang/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,
OpenPOWER on IntegriCloud