diff options
author | John McCall <rjmccall@apple.com> | 2010-01-28 01:42:12 +0000 |
---|---|---|
committer | John McCall <rjmccall@apple.com> | 2010-01-28 01:42:12 +0000 |
commit | 5357b615364c17ea024c757354c58ae2a520d216 (patch) | |
tree | ee929cb4cba153752e89f840b7a34312b2cc3c45 /lib/Sema/SemaAccess.cpp | |
parent | 7e20ffe322866f6a2e820e054da9bd0f6e9b0af4 (diff) |
Access checking for overloaded operators.
git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@94725 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'lib/Sema/SemaAccess.cpp')
-rw-r--r-- | lib/Sema/SemaAccess.cpp | 24 |
1 files changed, 24 insertions, 0 deletions
diff --git a/lib/Sema/SemaAccess.cpp b/lib/Sema/SemaAccess.cpp index f3c10392f7..34c9718014 100644 --- a/lib/Sema/SemaAccess.cpp +++ b/lib/Sema/SemaAccess.cpp @@ -306,6 +306,30 @@ bool Sema::CheckUnresolvedMemberAccess(UnresolvedMemberExpr *E, return false; } +/// Checks access to an overloaded member operator. +bool Sema::CheckMemberOperatorAccess(SourceLocation OpLoc, + Expr *ObjectExpr, + NamedDecl *MemberOperator, + AccessSpecifier Access) { + if (!getLangOptions().AccessControl) + return false; + + const RecordType *RT = ObjectExpr->getType()->getAs<RecordType>(); + assert(RT && "found member operator but object expr not of record type"); + CXXRecordDecl *NamingClass = cast<CXXRecordDecl>(RT->getDecl()); + + LookupResult R(*this, DeclarationName(), OpLoc, LookupOrdinaryName); + R.suppressDiagnostics(); + + R.setNamingClass(NamingClass); + if (CheckAccess(R, MemberOperator, Access)) + return true; + + // FIXME: protected check + + return false; +} + /// Checks access to all the declarations in the given result set. void Sema::CheckAccess(const LookupResult &R) { for (LookupResult::iterator I = R.begin(), E = R.end(); I != E; ++I) |