diff options
author | Eli Friedman <eli.friedman@gmail.com> | 2012-01-26 03:00:14 +0000 |
---|---|---|
committer | Eli Friedman <eli.friedman@gmail.com> | 2012-01-26 03:00:14 +0000 |
commit | 34b49061aad6d57c60d5bb15ad1cc44ff3968ae7 (patch) | |
tree | 5b8ea285f0097f649e7d098e674f84ad65fdd208 /clang/lib/Sema/SemaExpr.cpp | |
parent | e284163990e190b71d7fe99a46aca9063d73396a (diff) | |
download | bcm5719-llvm-34b49061aad6d57c60d5bb15ad1cc44ff3968ae7.tar.gz bcm5719-llvm-34b49061aad6d57c60d5bb15ad1cc44ff3968ae7.zip |
Refactor to share code for handling return statements between lambda expressions and block literals. As it turns out, almost all the logic can be shared.
llvm-svn: 149031
Diffstat (limited to 'clang/lib/Sema/SemaExpr.cpp')
-rw-r--r-- | clang/lib/Sema/SemaExpr.cpp | 3 |
1 files changed, 3 insertions, 0 deletions
diff --git a/clang/lib/Sema/SemaExpr.cpp b/clang/lib/Sema/SemaExpr.cpp index 8a53ece6b3c..018aadf8b91 100644 --- a/clang/lib/Sema/SemaExpr.cpp +++ b/clang/lib/Sema/SemaExpr.cpp @@ -8769,6 +8769,8 @@ void Sema::ActOnBlockStart(SourceLocation CaretLoc, Scope *CurScope) { else CurContext = Block; + getCurBlock()->HasImplicitReturnType = true; + // Enter a new evaluation context to insulate the block from any // cleanups from the enclosing full-expression. PushExpressionEvaluationContext(PotentiallyEvaluated); @@ -8835,6 +8837,7 @@ void Sema::ActOnBlockArguments(Declarator &ParamInfo, Scope *CurScope) { if (RetTy != Context.DependentTy) { CurBlock->ReturnType = RetTy; CurBlock->TheDecl->setBlockMissingReturnType(false); + CurBlock->HasImplicitReturnType = false; } // Push block parameters from the declarator if we had them. |