From 6781b05a9254f3aaf53126368d23ebda88e02c96 Mon Sep 17 00:00:00 2001 From: John McCall Date: Tue, 2 Feb 2010 08:45:54 +0000 Subject: Access control for implicit destructor calls. Diagnostic could be orders of magnitude clearer. llvm-svn: 95078 --- clang/lib/Sema/SemaAccess.cpp | 25 +++++++++++++++++++++++++ 1 file changed, 25 insertions(+) (limited to 'clang/lib/Sema/SemaAccess.cpp') 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(); + if (!Record) + return false; + + CXXRecordDecl *NamingClass = cast(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, -- cgit v1.2.3