summaryrefslogtreecommitdiffstats
path: root/clang
diff options
context:
space:
mode:
authorFariborz Jahanian <fjahanian@apple.com>2012-04-12 16:33:31 +0000
committerFariborz Jahanian <fjahanian@apple.com>2012-04-12 16:33:31 +0000
commite1240fe74367520150adabcbbda8ba55092c08a9 (patch)
treeed4cbbc96e67bb97e076ab7faca26d59cec8906b /clang
parent2c5154224b1bb9cdaf9ca8fb5c361171d6bdc122 (diff)
downloadbcm5719-llvm-e1240fe74367520150adabcbbda8ba55092c08a9.tar.gz
bcm5719-llvm-e1240fe74367520150adabcbbda8ba55092c08a9.zip
modern objective-c translator. ifdef'out
__weak and __block when rewriting. // rdar://11236342 llvm-svn: 154592
Diffstat (limited to 'clang')
-rw-r--r--clang/lib/Rewrite/RewriteModernObjC.cpp5
-rw-r--r--clang/test/Rewriter/rewrite-modern-block.mm7
2 files changed, 11 insertions, 1 deletions
diff --git a/clang/lib/Rewrite/RewriteModernObjC.cpp b/clang/lib/Rewrite/RewriteModernObjC.cpp
index fd621a2a5cc..ba62ad3c414 100644
--- a/clang/lib/Rewrite/RewriteModernObjC.cpp
+++ b/clang/lib/Rewrite/RewriteModernObjC.cpp
@@ -5726,7 +5726,12 @@ void RewriteModernObjC::Initialize(ASTContext &context) {
Preamble += "#ifndef KEEP_ATTRIBUTES\n"; // We use this for clang tests.
Preamble += "#define __attribute__(X)\n";
Preamble += "#endif\n";
+ Preamble += "#ifndef __weak\n";
Preamble += "#define __weak\n";
+ Preamble += "#endif\n";
+ Preamble += "#ifndef __block\n";
+ Preamble += "#define __block\n";
+ Preamble += "#endif\n";
}
else {
Preamble += "#define __block\n";
diff --git a/clang/test/Rewriter/rewrite-modern-block.mm b/clang/test/Rewriter/rewrite-modern-block.mm
index c5231bfcebc..8da723d319f 100644
--- a/clang/test/Rewriter/rewrite-modern-block.mm
+++ b/clang/test/Rewriter/rewrite-modern-block.mm
@@ -1,5 +1,5 @@
// RUN: %clang_cc1 -x objective-c++ -fblocks -fms-extensions -rewrite-objc %s -o %t-rw.cpp
-// RUN: %clang_cc1 -fsyntax-only -fblocks -Wno-address-of-temporary -D"Class=void*" -D"id=void*" -D"SEL=void*" -D"__declspec(X)=" %t-rw.cpp
+// RUN: %clang_cc1 -fsyntax-only -Wno-address-of-temporary -D"Class=void*" -D"id=void*" -D"SEL=void*" -D"__declspec(X)=" %t-rw.cpp
// rdar://11230308
typedef struct {
@@ -16,3 +16,8 @@ void y() {
x(&bytes);
};
}
+
+// rdar://11236342
+int foo() {
+ __block int hello;
+}
OpenPOWER on IntegriCloud