summaryrefslogtreecommitdiffstats
path: root/clang/test
diff options
context:
space:
mode:
authorFariborz Jahanian <fjahanian@apple.com>2013-01-08 23:17:51 +0000
committerFariborz Jahanian <fjahanian@apple.com>2013-01-08 23:17:51 +0000
commita716a345276c5868d966707b8c23c325be769d19 (patch)
treebc08e0dd6d258a92f026dc1a0116ca16e19562d5 /clang/test
parent6047163a244dc8c2ac7aebe96a84cf7d8e98cc71 (diff)
downloadbcm5719-llvm-a716a345276c5868d966707b8c23c325be769d19.tar.gz
bcm5719-llvm-a716a345276c5868d966707b8c23c325be769d19.zip
objectiveC blocks: It is impractical to capture
struct variables with flexiable array members in blocks (and lambdas). Issue error instead of crashing in IRGen. // rdar://12655829 llvm-svn: 171912
Diffstat (limited to 'clang/test')
-rw-r--r--clang/test/SemaObjCXX/capturing-flexible-array-in-block.mm9
1 files changed, 9 insertions, 0 deletions
diff --git a/clang/test/SemaObjCXX/capturing-flexible-array-in-block.mm b/clang/test/SemaObjCXX/capturing-flexible-array-in-block.mm
new file mode 100644
index 00000000000..4899c4653a6
--- /dev/null
+++ b/clang/test/SemaObjCXX/capturing-flexible-array-in-block.mm
@@ -0,0 +1,9 @@
+// RUN: %clang_cc1 -fsyntax-only -fblocks -verify -std=c++11 %s
+// rdar://12655829
+
+void f() {
+ struct { int x; int y[]; } a; // expected-note 2 {{'a' declared here}}
+ ^{return a.x;}(); // expected-error {{cannot refer to declaration of structure variable with flexible array member inside block}}
+
+ [] {return a.x;}(); // expected-error {{variable 'a' with flexible array member cannot be captured in a lambda expression}}
+}
OpenPOWER on IntegriCloud