diff options
| author | Anders Carlsson <andersca@mac.com> | 2009-09-10 23:18:36 +0000 |
|---|---|---|
| committer | Anders Carlsson <andersca@mac.com> | 2009-09-10 23:18:36 +0000 |
| commit | 78b549399413c64de40f99ab0d3a8f2b6b22adfb (patch) | |
| tree | 4ac8aa9c638467d81b7fb94b2c7504943ec8c893 /clang/lib | |
| parent | be6505cbd96d267b5fddf47a27f35c01ee9fe24d (diff) | |
| download | bcm5719-llvm-78b549399413c64de40f99ab0d3a8f2b6b22adfb.tar.gz bcm5719-llvm-78b549399413c64de40f99ab0d3a8f2b6b22adfb.zip | |
Look for overloaded arrow operators in base classes.
llvm-svn: 81475
Diffstat (limited to 'clang/lib')
| -rw-r--r-- | clang/lib/Sema/SemaOverload.cpp | 12 |
1 files changed, 7 insertions, 5 deletions
diff --git a/clang/lib/Sema/SemaOverload.cpp b/clang/lib/Sema/SemaOverload.cpp index 7e179793d70..4891527e7b2 100644 --- a/clang/lib/Sema/SemaOverload.cpp +++ b/clang/lib/Sema/SemaOverload.cpp @@ -4878,9 +4878,11 @@ Sema::BuildOverloadedArrowExpr(Scope *S, ExprArg BaseIn, SourceLocation OpLoc) { OverloadCandidateSet CandidateSet; const RecordType *BaseRecord = Base->getType()->getAs<RecordType>(); - DeclContext::lookup_const_iterator Oper, OperEnd; - for (llvm::tie(Oper, OperEnd) - = BaseRecord->getDecl()->lookup(OpName); Oper != OperEnd; ++Oper) + LookupResult R = LookupQualifiedName(BaseRecord->getDecl(), OpName, + LookupOrdinaryName); + + for (LookupResult::iterator Oper = R.begin(), OperEnd = R.end(); + Oper != OperEnd; ++Oper) AddMethodCandidate(cast<CXXMethodDecl>(*Oper), Base, 0, 0, CandidateSet, /*SuppressUserConversions=*/false); @@ -4903,14 +4905,14 @@ Sema::BuildOverloadedArrowExpr(Scope *S, ExprArg BaseIn, SourceLocation OpLoc) { case OR_Ambiguous: Diag(OpLoc, diag::err_ovl_ambiguous_oper) - << "operator->" << Base->getSourceRange(); + << "->" << Base->getSourceRange(); PrintOverloadCandidates(CandidateSet, /*OnlyViable=*/true); return ExprError(); case OR_Deleted: Diag(OpLoc, diag::err_ovl_deleted_oper) << Best->Function->isDeleted() - << "operator->" << Base->getSourceRange(); + << "->" << Base->getSourceRange(); PrintOverloadCandidates(CandidateSet, /*OnlyViable=*/true); return ExprError(); } |

