From: Fariborz Jahanian Date: Sun, 31 Jul 2011 20:27:31 +0000 (+0000) Subject: Test for // rdar://9846759 X-Git-Url: https://granicus.if.org/sourcecode?a=commitdiff_plain;h=9d9e3dd6ee20ff5bc48d8ef0a2880c3753d87984;p=clang Test for // rdar://9846759 git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@136602 91177308-0d34-0410-b5e6-96231b3b80d8 --- diff --git a/test/Rewriter/inner-block-helper-funcs.mm b/test/Rewriter/inner-block-helper-funcs.mm new file mode 100644 index 0000000000..33567bc3d7 --- /dev/null +++ b/test/Rewriter/inner-block-helper-funcs.mm @@ -0,0 +1,32 @@ +// RUN: %clang_cc1 -x objective-c++ -fblocks -fms-extensions -rewrite-objc %s -o %t-rw.cpp +// RUN: FileCheck -check-prefix LP --input-file=%t-rw.cpp %s +// rdar://9846759 + +typedef void (^dispatch_block_t)(void); + +extern int printf(const char*, ...); + +extern "C" dispatch_block_t Block_copy(dispatch_block_t aBlock); + +int main (int argc, char *argv[]) { + + dispatch_block_t innerBlock = ^{printf("argc = %d\n", argc); }; + id innerObject = 0; + + printf("innerBlock is %x\n", innerBlock); + + dispatch_block_t wrapperBlock = ^{ + printf("innerBlock is %x %x\n", innerBlock, innerObject); + }; + + wrapperBlock(); + + dispatch_block_t copiedBlock = Block_copy(wrapperBlock); + copiedBlock(); + + return 0; +} +// CHECK-LP: _Block_object_assign((void*)&dst->innerBlock, (void*)src->innerBlock, 7 +// CHECK-LP: _Block_object_dispose((void*)src->innerBlock, 7 +// CHECK-LP: _Block_object_assign((void*)&dst->innerObject, (void*)src->innerObject, 3 +// CHECK-LP: _Block_object_dispose((void*)src->innerObject, 3