diff options
author | Douglas Gregor <dgregor@apple.com> | 2013-03-07 22:38:24 +0000 |
---|---|---|
committer | Douglas Gregor <dgregor@apple.com> | 2013-03-07 22:38:24 +0000 |
commit | ca00645e4cc0fe255e7cf31545254cf6bb97e90e (patch) | |
tree | bd535280c72fd8b09d6539aff04a6228d5969a68 /clang/lib/Sema | |
parent | 3d27e6603a1605ccf6bae568ca86ddc5aa266f96 (diff) | |
download | bcm5719-llvm-ca00645e4cc0fe255e7cf31545254cf6bb97e90e.tar.gz bcm5719-llvm-ca00645e4cc0fe255e7cf31545254cf6bb97e90e.zip |
When possible, move __block variables to the heap rather than copying them.
Fixes <rdar://problem/13330126>.
llvm-svn: 176663
Diffstat (limited to 'clang/lib/Sema')
-rw-r--r-- | clang/lib/Sema/SemaDecl.cpp | 8 |
1 files changed, 4 insertions, 4 deletions
diff --git a/clang/lib/Sema/SemaDecl.cpp b/clang/lib/Sema/SemaDecl.cpp index 82d216ee01c..4fa790515da 100644 --- a/clang/lib/Sema/SemaDecl.cpp +++ b/clang/lib/Sema/SemaDecl.cpp @@ -7811,10 +7811,10 @@ void Sema::CheckCompleteVariableDeclaration(VarDecl *var) { if (type->isStructureOrClassType()) { SourceLocation poi = var->getLocation(); Expr *varRef =new (Context) DeclRefExpr(var, false, type, VK_LValue, poi); - ExprResult result = - PerformCopyInitialization( - InitializedEntity::InitializeBlock(poi, type, false), - poi, Owned(varRef)); + ExprResult result + = PerformMoveOrCopyInitialization( + InitializedEntity::InitializeBlock(poi, type, false), + var, var->getType(), varRef, /*AllowNRVO=*/true); if (!result.isInvalid()) { result = MaybeCreateExprWithCleanups(result); Expr *init = result.takeAs<Expr>(); |