aboutsummaryrefslogtreecommitdiff
path: root/lib/Sema/SemaStmt.cpp
diff options
context:
space:
mode:
authorJohn McCall <rjmccall@apple.com>2011-08-17 21:34:14 +0000
committerJohn McCall <rjmccall@apple.com>2011-08-17 21:34:14 +0000
commitd963c37eb912342c8325048749e449861cf0a6e3 (patch)
tree8c3ba183cec56377add9f4102b6c56688aad9fc3 /lib/Sema/SemaStmt.cpp
parent6704429557544a890cf6c0859b13b1dc63572f70 (diff)
Gather cleanups correctly in block return statements.
Thanks to Ted for finding this with magic tools. git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@137877 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'lib/Sema/SemaStmt.cpp')
-rw-r--r--lib/Sema/SemaStmt.cpp19
1 files changed, 7 insertions, 12 deletions
diff --git a/lib/Sema/SemaStmt.cpp b/lib/Sema/SemaStmt.cpp
index 7219718ba4..8303616db4 100644
--- a/lib/Sema/SemaStmt.cpp
+++ b/lib/Sema/SemaStmt.cpp
@@ -1741,21 +1741,17 @@ Sema::ActOnBlockReturnStmt(SourceLocation ReturnLoc, Expr *RetValExp) {
// pickier with blocks than for normal functions because we don't have GCC
// compatibility to worry about here.
ReturnStmt *Result = 0;
+ const VarDecl *NRVOCandidate = 0;
if (CurBlock->ReturnType->isVoidType()) {
if (RetValExp && !RetValExp->isTypeDependent() &&
(!getLangOptions().CPlusPlus || !RetValExp->getType()->isVoidType())) {
Diag(ReturnLoc, diag::err_return_block_has_expr);
RetValExp = 0;
}
- Result = new (Context) ReturnStmt(ReturnLoc, RetValExp, 0);
} else if (!RetValExp) {
if (!CurBlock->ReturnType->isDependentType())
return StmtError(Diag(ReturnLoc, diag::err_block_return_missing_expr));
-
- Result = new (Context) ReturnStmt(ReturnLoc, 0, 0);
} else {
- const VarDecl *NRVOCandidate = 0;
-
if (!FnRetType->isDependentType() && !RetValExp->isTypeDependent()) {
// we have a non-void block with an expression, continue checking
@@ -1775,19 +1771,18 @@ Sema::ActOnBlockReturnStmt(SourceLocation ReturnLoc, Expr *RetValExp) {
// FIXME: Cleanup temporaries here, anyway?
return StmtError();
}
+ RetValExp = Res.take();
- if (RetValExp) {
- CheckImplicitConversions(RetValExp, ReturnLoc);
- RetValExp = MaybeCreateExprWithCleanups(RetValExp);
- }
-
- RetValExp = Res.takeAs<Expr>();
if (RetValExp)
CheckReturnStackAddr(RetValExp, FnRetType, ReturnLoc);
}
+ }
- Result = new (Context) ReturnStmt(ReturnLoc, RetValExp, NRVOCandidate);
+ if (RetValExp) {
+ CheckImplicitConversions(RetValExp, ReturnLoc);
+ RetValExp = MaybeCreateExprWithCleanups(RetValExp);
}
+ Result = new (Context) ReturnStmt(ReturnLoc, RetValExp, NRVOCandidate);
// If we need to check for the named return value optimization, save the
// return statement in our scope for later processing.