diff options
Diffstat (limited to 'clang/Sema')
| -rw-r--r-- | clang/Sema/SemaDeclObjC.cpp | 16 | ||||
| -rw-r--r-- | clang/Sema/SemaExpr.cpp | 19 |
2 files changed, 14 insertions, 21 deletions
diff --git a/clang/Sema/SemaDeclObjC.cpp b/clang/Sema/SemaDeclObjC.cpp index d520c4f357c..946d12f5c06 100644 --- a/clang/Sema/SemaDeclObjC.cpp +++ b/clang/Sema/SemaDeclObjC.cpp @@ -24,6 +24,12 @@ void Sema::ObjcActOnStartOfMethodDef(Scope *FnBodyScope, DeclTy *D) { assert(CurFunctionDecl == 0 && "Method parsing confused"); ObjcMethodDecl *MDecl = dyn_cast<ObjcMethodDecl>(static_cast<Decl *>(D)); assert(MDecl != 0 && "Not a method declarator!"); + + // Allow the rest of sema to find private method decl implementations. + if (MDecl->isInstance()) + AddInstanceMethodToGlobalPool(MDecl); + else + AddFactoryMethodToGlobalPool(MDecl); // Allow all of Sema to see that we are entering a method definition. CurMethodDecl = MDecl; @@ -666,13 +672,15 @@ void Sema::AddFactoryMethodToGlobalPool(ObjcMethodDecl *Method) { } } +// Note: For class/category implemenations, allMethods/allProperties is +// always null. void Sema::ActOnAtEnd(SourceLocation AtEndLoc, DeclTy *classDecl, DeclTy **allMethods, unsigned allNum, DeclTy **allProperties, unsigned pNum) { Decl *ClassDecl = static_cast<Decl *>(classDecl); - // FIXME: If we don't have a ClassDecl, we have an error. I (snaroff) would - // prefer we always pass in a decl. If the decl has an error, isInvalidDecl() + // FIXME: If we don't have a ClassDecl, we have an error. We should consider + // always passing in a decl. If the decl has an error, isInvalidDecl() // should be true. if (!ClassDecl) return; @@ -731,8 +739,8 @@ void Sema::ActOnAtEnd(SourceLocation AtEndLoc, DeclTy *classDecl, } else { clsMethods.push_back(Method); ClsMap[Method->getSelector()] = Method; - /// The following allows us to typecheck messages to "id". - AddInstanceMethodToGlobalPool(Method); + /// The following allows us to typecheck messages to "Class". + AddFactoryMethodToGlobalPool(Method); } } } diff --git a/clang/Sema/SemaExpr.cpp b/clang/Sema/SemaExpr.cpp index 45d04705447..e5f748fa667 100644 --- a/clang/Sema/SemaExpr.cpp +++ b/clang/Sema/SemaExpr.cpp @@ -2264,23 +2264,8 @@ Sema::ExprResult Sema::ActOnInstanceMessage( if (receiverType == Context.getObjcIdType() || receiverType == Context.getObjcClassType()) { Method = InstanceMethodPool[Sel].Method; - // If we didn't find an public method, look for a private one. - if (!Method && CurMethodDecl) { - NamedDecl *impCxt = CurMethodDecl->getMethodContext(); - if (ObjcImplementationDecl *IMD = - dyn_cast<ObjcImplementationDecl>(impCxt)) { - if (receiverType == Context.getObjcIdType()) - Method = IMD->lookupInstanceMethod(Sel); - else - Method = IMD->lookupClassMethod(Sel); - } else if (ObjcCategoryImplDecl *CID = - dyn_cast<ObjcCategoryImplDecl>(impCxt)) { - if (receiverType == Context.getObjcIdType()) - Method = CID->lookupInstanceMethod(Sel); - else - Method = CID->lookupClassMethod(Sel); - } - } + if (!Method) + Method = FactoryMethodPool[Sel].Method; if (!Method) { Diag(lbrac, diag::warn_method_not_found, std::string("-"), Sel.getName(), SourceRange(lbrac, rbrac)); |

