diff options
| author | John McCall <rjmccall@apple.com> | 2010-01-28 07:38:46 +0000 |
|---|---|---|
| committer | John McCall <rjmccall@apple.com> | 2010-01-28 07:38:46 +0000 |
| commit | 2cb941642e87e07befed66cc96f36a4d37556911 (patch) | |
| tree | 007df968133fecb9012cf1970743f87b8d85b725 /clang/lib | |
| parent | 1051937c214309dfa42f861feca2bf420b1f2edb (diff) | |
| download | bcm5719-llvm-2cb941642e87e07befed66cc96f36a4d37556911.tar.gz bcm5719-llvm-2cb941642e87e07befed66cc96f36a4d37556911.zip | |
Access control for surrogate function calls. Required a moderately gross hack
to get the access bits set properly in conversion sets.
llvm-svn: 94744
Diffstat (limited to 'clang/lib')
| -rw-r--r-- | clang/lib/Sema/SemaDeclCXX.cpp | 5 | ||||
| -rw-r--r-- | clang/lib/Sema/SemaOverload.cpp | 6 |
2 files changed, 8 insertions, 3 deletions
diff --git a/clang/lib/Sema/SemaDeclCXX.cpp b/clang/lib/Sema/SemaDeclCXX.cpp index f65dc4bd668..566e915bc01 100644 --- a/clang/lib/Sema/SemaDeclCXX.cpp +++ b/clang/lib/Sema/SemaDeclCXX.cpp @@ -2086,6 +2086,11 @@ void Sema::CheckCompletedCXXClass(CXXRecordDecl *Record) { if (Record->isInvalidDecl()) return; + // Set access bits correctly on the directly-declared conversions. + UnresolvedSetImpl *Convs = Record->getConversionFunctions(); + for (UnresolvedSetIterator I = Convs->begin(), E = Convs->end(); I != E; ++I) + Convs->setAccess(I, (*I)->getAccess()); + if (!Record->isAbstract()) { // Collect all the pure virtual methods and see if this is an abstract // class after all. diff --git a/clang/lib/Sema/SemaOverload.cpp b/clang/lib/Sema/SemaOverload.cpp index 55259fca4f2..86b1e37f108 100644 --- a/clang/lib/Sema/SemaOverload.cpp +++ b/clang/lib/Sema/SemaOverload.cpp @@ -6231,7 +6231,7 @@ Sema::BuildCallToObjectOfClassType(Scope *S, Expr *Object, = cast<CXXConversionDecl>( Best->Conversions[0].UserDefined.ConversionFunction); - // FIXME: access control + CheckMemberOperatorAccess(LParenLoc, Object, Conv, Best->getAccess()); // We selected one of the surrogate functions that converts the // object parameter to a function pointer. Perform the conversion @@ -6246,8 +6246,8 @@ Sema::BuildCallToObjectOfClassType(Scope *S, Expr *Object, CommaLocs, RParenLoc).release(); } - if (getLangOptions().AccessControl) - CheckAccess(R, Best->Function, Best->getAccess()); + CheckMemberOperatorAccess(LParenLoc, Object, + Best->Function, Best->getAccess()); // We found an overloaded operator(). Build a CXXOperatorCallExpr // that calls this method, using Object for the implicit object |

