summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorFariborz Jahanian <fjahanian@apple.com>2010-05-27 16:05:06 +0000
committerFariborz Jahanian <fjahanian@apple.com>2010-05-27 16:05:06 +0000
commit9ea5839cb68e4a2be3158cabf2f45f86421c7a8b (patch)
treef67f994ad976585c6d1e9d4338012465e19888cd
parent205a3614135716b20b77ad1901332095dc2fa0f3 (diff)
downloadbcm5719-llvm-9ea5839cb68e4a2be3158cabf2f45f86421c7a8b.tar.gz
bcm5719-llvm-9ea5839cb68e4a2be3158cabf2f45f86421c7a8b.zip
Objective-c++ IR gen.
Flag synthesized struct decl. as non-empty so CXX side of ir gen does not skip its Null initialization. Fixes radar 8027844 for objc++'s collection statement. llvm-svn: 104837
-rw-r--r--clang/lib/AST/ASTContext.cpp3
-rw-r--r--clang/test/CodeGenObjCXX/foreach-statement.mm10
2 files changed, 13 insertions, 0 deletions
diff --git a/clang/lib/AST/ASTContext.cpp b/clang/lib/AST/ASTContext.cpp
index 851f8d1c68b..60d7117bbf9 100644
--- a/clang/lib/AST/ASTContext.cpp
+++ b/clang/lib/AST/ASTContext.cpp
@@ -2856,6 +2856,9 @@ QualType ASTContext::getObjCFastEnumerationStateType() {
Field->setAccess(AS_public);
ObjCFastEnumerationStateTypeDecl->addDecl(Field);
}
+ if (getLangOptions().CPlusPlus)
+ if (CXXRecordDecl *CXXRD = dyn_cast<CXXRecordDecl>(ObjCFastEnumerationStateTypeDecl))
+ CXXRD->setEmpty(false);
ObjCFastEnumerationStateTypeDecl->completeDefinition();
}
diff --git a/clang/test/CodeGenObjCXX/foreach-statement.mm b/clang/test/CodeGenObjCXX/foreach-statement.mm
new file mode 100644
index 00000000000..d0ad5b3a8f0
--- /dev/null
+++ b/clang/test/CodeGenObjCXX/foreach-statement.mm
@@ -0,0 +1,10 @@
+// RUN: %clang_cc1 %s -triple=x86_64-apple-darwin10 -emit-llvm -o - | FileCheck %s
+// rdar: // 8027844
+
+// CHECK: call void @llvm.memset
+
+int main() {
+ id foo;
+ for (id a in foo) {
+ }
+}
OpenPOWER on IntegriCloud