summaryrefslogtreecommitdiffstats
path: root/clang/test
diff options
context:
space:
mode:
authorFariborz Jahanian <fjahanian@apple.com>2011-02-16 22:37:10 +0000
committerFariborz Jahanian <fjahanian@apple.com>2011-02-16 22:37:10 +0000
commit9cd649d37648eb3651a00c6703a747ed293c4139 (patch)
tree0b803ecb8257face8b1cc73e4719747bb951bb64 /clang/test
parent4890c85e0af49729b4fb2affa742a5df5e47fff0 (diff)
downloadbcm5719-llvm-9cd649d37648eb3651a00c6703a747ed293c4139.tar.gz
bcm5719-llvm-9cd649d37648eb3651a00c6703a747ed293c4139.zip
Block rewriting bug. Don't take address of captured
byref variables again when passing them to inner blocks. // rdar://9006279 llvm-svn: 125690
Diffstat (limited to 'clang/test')
-rw-r--r--clang/test/Rewriter/rewrite-captured-nested-bvar.c35
1 files changed, 35 insertions, 0 deletions
diff --git a/clang/test/Rewriter/rewrite-captured-nested-bvar.c b/clang/test/Rewriter/rewrite-captured-nested-bvar.c
new file mode 100644
index 00000000000..a48de4bbeae
--- /dev/null
+++ b/clang/test/Rewriter/rewrite-captured-nested-bvar.c
@@ -0,0 +1,35 @@
+// RUN: %clang_cc1 -x c -fblocks -fms-extensions -rewrite-objc %s -o %t-rw.cpp
+// RUN: FileCheck --input-file=%t-rw.cpp %s
+// rdar://9006279
+
+void q(void (^p)(void)) {
+ p();
+}
+
+void f() {
+ __block char BYREF_VAR_CHECK = 'a';
+ __block char d = 'd';
+ q(^{
+ q(^{
+ __block char e = 'e';
+ char l = 'l';
+ BYREF_VAR_CHECK = 'b';
+ d = 'd';
+ q(^{
+ e = '1';
+ BYREF_VAR_CHECK = '2';
+ d = '3';
+ }
+ );
+ });
+ });
+}
+
+int main() {
+ f();
+ return 0;
+}
+
+// CHECK 2: (__Block_byref_BYREF_VAR_CHECK_0 *)BYREF_VAR_CHECK
+// CHECK: (__Block_byref_BYREF_VAR_CHECK_0 *)&BYREF_VAR_CHECK
+// CHECK: (struct __Block_byref_BYREF_VAR_CHECK_0 *)&BYREF_VAR_CHECK, (struct __Block_byref_d_1 *)&d, 570425344));
OpenPOWER on IntegriCloud