diff options
| author | Steve Naroff <snaroff@apple.com> | 2008-07-25 17:57:26 +0000 |
|---|---|---|
| committer | Steve Naroff <snaroff@apple.com> | 2008-07-25 17:57:26 +0000 |
| commit | 542cd5d3f974db68ba08f4a6d4742a39deea88e6 (patch) | |
| tree | dab762c01689a3c387c26cf928ba7ca8ac97265e | |
| parent | 098cc6f22c26ff75f7483fad5e77f75fe4e9d8a2 (diff) | |
| download | bcm5719-llvm-542cd5d3f974db68ba08f4a6d4742a39deea88e6.tar.gz bcm5719-llvm-542cd5d3f974db68ba08f4a6d4742a39deea88e6.zip | |
Move fix in r54013 from the parser to sema.
llvm-svn: 54032
| -rw-r--r-- | clang/lib/Parse/ParseObjc.cpp | 9 | ||||
| -rw-r--r-- | clang/lib/Sema/SemaDecl.cpp | 7 | ||||
| -rw-r--r-- | clang/lib/Sema/SemaDeclObjC.cpp | 7 |
3 files changed, 12 insertions, 11 deletions
diff --git a/clang/lib/Parse/ParseObjc.cpp b/clang/lib/Parse/ParseObjc.cpp index 38379b14e6b..7d7ba10a38b 100644 --- a/clang/lib/Parse/ParseObjc.cpp +++ b/clang/lib/Parse/ParseObjc.cpp @@ -1292,10 +1292,8 @@ Parser::DeclTy *Parser::ParseObjCMethodDefinition() { EnterScope(Scope::FnScope|Scope::DeclScope); // Tell the actions module that we have entered a method definition with the - // specified Declarator for the method. If we don't have an MDecl, avoid - // calling the actions module. - if (MDecl) - Actions.ObjCActOnStartOfMethodDef(CurScope, MDecl); + // specified Declarator for the method. + Actions.ObjCActOnStartOfMethodDef(CurScope, MDecl); StmtResult FnBody = ParseCompoundStatementBody(); @@ -1307,8 +1305,7 @@ Parser::DeclTy *Parser::ParseObjCMethodDefinition() { ExitScope(); // TODO: Pass argument information. - if (MDecl) - Actions.ActOnFinishFunctionBody(MDecl, FnBody.Val); + Actions.ActOnFinishFunctionBody(MDecl, FnBody.Val); return MDecl; } diff --git a/clang/lib/Sema/SemaDecl.cpp b/clang/lib/Sema/SemaDecl.cpp index 25d4ad5751b..4d726cf0a85 100644 --- a/clang/lib/Sema/SemaDecl.cpp +++ b/clang/lib/Sema/SemaDecl.cpp @@ -1576,12 +1576,13 @@ Sema::DeclTy *Sema::ActOnStartOfFunctionDef(Scope *FnBodyScope, DeclTy *D) { Sema::DeclTy *Sema::ActOnFinishFunctionBody(DeclTy *D, StmtTy *Body) { Decl *dcl = static_cast<Decl *>(D); - if (FunctionDecl *FD = dyn_cast<FunctionDecl>(dcl)) { + if (FunctionDecl *FD = dyn_cast_or_null<FunctionDecl>(dcl)) { FD->setBody((Stmt*)Body); assert(FD == getCurFunctionDecl() && "Function parsing confused"); - } else if (ObjCMethodDecl *MD = dyn_cast<ObjCMethodDecl>(dcl)) { + } else if (ObjCMethodDecl *MD = dyn_cast_or_null<ObjCMethodDecl>(dcl)) { MD->setBody((Stmt*)Body); - } + } else + return 0; PopDeclContext(); // Verify and clean out per-function state. diff --git a/clang/lib/Sema/SemaDeclObjC.cpp b/clang/lib/Sema/SemaDeclObjC.cpp index f71f4f4b786..79f1e2d6823 100644 --- a/clang/lib/Sema/SemaDeclObjC.cpp +++ b/clang/lib/Sema/SemaDeclObjC.cpp @@ -22,8 +22,11 @@ using namespace clang; /// and user declared, in the method definition's AST. void Sema::ObjCActOnStartOfMethodDef(Scope *FnBodyScope, DeclTy *D) { assert(getCurMethodDecl() == 0 && "Method parsing confused"); - ObjCMethodDecl *MDecl = dyn_cast<ObjCMethodDecl>(static_cast<Decl *>(D)); - assert(MDecl != 0 && "Not a method declarator!"); + ObjCMethodDecl *MDecl = dyn_cast_or_null<ObjCMethodDecl>((Decl *)D); + + // If we don't have a valid method decl, simply return. + if (!MDecl) + return; // Allow the rest of sema to find private method decl implementations. if (MDecl->isInstance()) |

