diff options
| author | Fariborz Jahanian <fjahanian@apple.com> | 2012-04-12 16:33:31 +0000 |
|---|---|---|
| committer | Fariborz Jahanian <fjahanian@apple.com> | 2012-04-12 16:33:31 +0000 |
| commit | e1240fe74367520150adabcbbda8ba55092c08a9 (patch) | |
| tree | ed4cbbc96e67bb97e076ab7faca26d59cec8906b /clang | |
| parent | 2c5154224b1bb9cdaf9ca8fb5c361171d6bdc122 (diff) | |
| download | bcm5719-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.cpp | 5 | ||||
| -rw-r--r-- | clang/test/Rewriter/rewrite-modern-block.mm | 7 |
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; +} |

