diff options
author | Alex Lorenz <arphaman@gmail.com> | 2017-04-06 12:53:43 +0000 |
---|---|---|
committer | Alex Lorenz <arphaman@gmail.com> | 2017-04-06 12:53:43 +0000 |
commit | b4791c7595eb1637c6371b1ec30756631c2c7f32 (patch) | |
tree | fa11b0602ee05827d7a53c2ec57cbf0b4f7418e4 /clang/test | |
parent | e228f68811ffe816faaa892b27dafb788393aba8 (diff) | |
download | bcm5719-llvm-b4791c7595eb1637c6371b1ec30756631c2c7f32.tar.gz bcm5719-llvm-b4791c7595eb1637c6371b1ec30756631c2c7f32.zip |
Fix lambda to block conversion in C++17 by avoiding copy elision for the
lambda capture used by the created block
The commit r288866 introduced guaranteed copy elision to C++ 17. This
unfortunately broke the lambda to block conversion in C++17 (the compiler
crashes when performing IRGen). This commit fixes the conversion by avoiding
copy elision for the capture that captures the lambda that's used in the block
created by the lambda to block conversion process.
rdar://31385153
Differential Revision: https://reviews.llvm.org/D31669
llvm-svn: 299646
Diffstat (limited to 'clang/test')
-rw-r--r-- | clang/test/CodeGenObjCXX/lambda-to-block.mm | 18 |
1 files changed, 18 insertions, 0 deletions
diff --git a/clang/test/CodeGenObjCXX/lambda-to-block.mm b/clang/test/CodeGenObjCXX/lambda-to-block.mm new file mode 100644 index 00000000000..a8d0718b124 --- /dev/null +++ b/clang/test/CodeGenObjCXX/lambda-to-block.mm @@ -0,0 +1,18 @@ +// RUN: %clang_cc1 -x objective-c++ -fblocks -triple x86_64-apple-darwin10 -fobjc-runtime=macosx-fragile-10.5 -std=c++1z -emit-llvm -o - %s | FileCheck %s + +// rdar://31385153 +// Shouldn't crash! + +void takesBlock(void (^)(void)); + +struct Copyable { + Copyable(const Copyable &x); +}; + +void hasLambda(Copyable x) { + takesBlock([x] () { }); +} +// CHECK-LABEL: define internal void @__copy_helper_block_ +// CHECK: call void @"_ZZ9hasLambda8CopyableEN3$_0C1ERKS0_" +// CHECK-LABEL: define internal void @"_ZZ9hasLambda8CopyableEN3$_0C2ERKS0_" +// CHECK: call void @_ZN8CopyableC1ERKS_ |