| // RUN: %clang_cc1 -no-opaque-pointers -no-enable-noundef-analysis -fblocks -disable-llvm-passes -triple x86_64-apple-darwin10 -std=c++17 -emit-llvm -o - %s | FileCheck %s |
| typedef void (*fnptr_t)(); |
| blk_t operator+(blk_t lhs, T) { return lhs; } |
| fnptr_t operator+(fnptr_t lhs, T) { return lhs; } |
| // CHECK-LABEL: define{{.*}} void @_Z2t1P1X |
| // Check that we call lambda.operator blk_t(), and that we send that result to |
| // CHECK: [[CALL:%.*]] = call void ()* @"_ZZ2t1P1XENK3$_0cvU13block_pointerFvvEEv" |
| // CHECK: call void{{.*}}@objc_msgSend{{.*}}({{.*}} void ()* [[CALL]]) |
| // CHECK: [[CALL2:%.*]] = call void ()* @"_ZZ2t1P1XENK3$_1cvPFvvEEv" |
| // CHECK: call void{{.*}}@objc_msgSend{{.*}}({{.*}} void ()* [[CALL2]]) |
| // CHECK-LABEL: define{{.*}} void @_Z2t2P1X |
| // Test the case when the lambda isn't unique. (see OpaqueValueExpr::isUnique) |
| // FIXME: This asserts if the lambda isn't trivially copy/movable. |
| // [x setBlk: operator+([x blk], [] {})] |
| // CHECK: call void{{.*}}@objc_msgSend{{.*}} |
| // CHECK: [[PLUS:%.*]] = call void ()* @"_ZplIZ2t2P1XE3$_0EU13block_pointerFvvES4_T_" |
| // CHECK: call void{{.*}}@objc_msgSend{{.*}}({{.*}} [[PLUS]]) |
| // CHECK: call void{{.*}}@objc_msgSend{{.*}} |
| // CHECK: [[PLUS:%.*]] = call void ()* @"_ZplIZ2t2P1XE3$_1EPFvvES4_T_" |
| // CHECK: call void{{.*}}@objc_msgSend{{.*}}({{.*}} [[PLUS]]) |