aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorAnders Carlsson <andersca@mac.com>2009-05-15 20:29:28 +0000
committerAnders Carlsson <andersca@mac.com>2009-05-15 20:29:28 +0000
commite28be4386b3b2af45462339fc04c0924ffa78e93 (patch)
treee17b847d134db0753cbe6cbe210b1b7fab644860
parent0712d29123215e00b9e5b3c89746c90d9624830f (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.cpp11
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));
}