diff options
author | Anders Carlsson <andersca@mac.com> | 2009-05-15 20:29:28 +0000 |
---|---|---|
committer | Anders Carlsson <andersca@mac.com> | 2009-05-15 20:29:28 +0000 |
commit | e28be4386b3b2af45462339fc04c0924ffa78e93 (patch) | |
tree | e17b847d134db0753cbe6cbe210b1b7fab644860 | |
parent | 0712d29123215e00b9e5b3c89746c90d9624830f (diff) |
I take it back, InstantiateExpr does not check for null.
git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@71887 91177308-0d34-0410-b5e6-96231b3b80d8
-rw-r--r-- | lib/Sema/SemaTemplateInstantiateStmt.cpp | 11 |
1 files changed, 7 insertions, 4 deletions
diff --git a/lib/Sema/SemaTemplateInstantiateStmt.cpp b/lib/Sema/SemaTemplateInstantiateStmt.cpp index 8bdb42b58f..957402ac6f 100644 --- a/lib/Sema/SemaTemplateInstantiateStmt.cpp +++ b/lib/Sema/SemaTemplateInstantiateStmt.cpp @@ -98,10 +98,13 @@ Sema::OwningStmtResult TemplateStmtInstantiator::VisitGotoStmt(GotoStmt *S) { Sema::OwningStmtResult TemplateStmtInstantiator::VisitReturnStmt(ReturnStmt *S) { - Sema::OwningExprResult Result = - SemaRef.InstantiateExpr(S->getRetValue(), TemplateArgs); - if (Result.isInvalid()) - return SemaRef.StmtError(); + Sema::OwningExprResult Result = SemaRef.ExprEmpty(); + if (Expr *E = S->getRetValue()) { + Result = SemaRef.InstantiateExpr(E, TemplateArgs); + + if (Result.isInvalid()) + return SemaRef.StmtError(); + } return SemaRef.ActOnReturnStmt(S->getReturnLoc(), move(Result)); } |