2011-10-04 14:23:45 +08:00
|
|
|
// RUN: %clang_cc1 -fobjc-arc -fblocks -emit-llvm %s -o - | FileCheck %s
|
|
|
|
|
|
|
|
typedef void (^block_t)(void);
|
|
|
|
void use_block(block_t);
|
|
|
|
void use_int(int);
|
|
|
|
|
|
|
|
// rdar://problem/10211676
|
|
|
|
|
|
|
|
void test0(int i) {
|
|
|
|
block_t block = ^{ use_int(i); };
|
2013-08-15 14:47:53 +08:00
|
|
|
// CHECK-LABEL: define void @test0(
|
2013-02-22 17:10:20 +08:00
|
|
|
// CHECK: call i8* @objc_retainBlock(i8* {{%.*}}) [[NUW:#[0-9]+]], !clang.arc.copy_on_escape
|
2011-10-04 14:23:45 +08:00
|
|
|
// CHECK: ret void
|
|
|
|
}
|
|
|
|
|
|
|
|
void test1(int i) {
|
|
|
|
id block = ^{ use_int(i); };
|
2013-08-15 14:47:53 +08:00
|
|
|
// CHECK-LABEL: define void @test1(
|
2013-02-22 17:10:20 +08:00
|
|
|
// CHECK: call i8* @objc_retainBlock(i8* {{%.*}}) [[NUW]]
|
2011-10-04 14:23:45 +08:00
|
|
|
// CHECK-NOT: !clang.arc.copy_on_escape
|
|
|
|
// CHECK: ret void
|
|
|
|
}
|
2013-02-22 17:10:20 +08:00
|
|
|
|
|
|
|
// CHECK: attributes [[NUW]] = { nounwind }
|