summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorFariborz Jahanian <fjahanian@apple.com>2010-01-12 18:33:57 +0000
committerFariborz Jahanian <fjahanian@apple.com>2010-01-12 18:33:57 +0000
commit42c06998ea9dd5c58cb9d71f161a935b998c57e3 (patch)
treecec0c6ed1bd6548d566147d478c14fd031767523
parent08557ef5f47840ebb185046591690a4d0c9dc4a1 (diff)
downloadbcm5719-llvm-42c06998ea9dd5c58cb9d71f161a935b998c57e3.tar.gz
bcm5719-llvm-42c06998ea9dd5c58cb9d71f161a935b998c57e3.zip
Define __weak attribute for objective-c pointers in
win32 targets. Fixes radar 7530235. Daniel please review. llvm-svn: 93246
-rw-r--r--clang/lib/Basic/Targets.cpp4
-rw-r--r--clang/test/Rewriter/rewrite-weak-attr.m13
2 files changed, 17 insertions, 0 deletions
diff --git a/clang/lib/Basic/Targets.cpp b/clang/lib/Basic/Targets.cpp
index ac13b950752..ef3cf89299e 100644
--- a/clang/lib/Basic/Targets.cpp
+++ b/clang/lib/Basic/Targets.cpp
@@ -994,6 +994,10 @@ public:
DefineStd(Builder, "WIN32", Opts);
DefineStd(Builder, "WINNT", Opts);
Builder.defineMacro("_X86_");
+ if (Opts.ObjC1)
+ // __weak is always defined, for use in blocks and with objc pointers,
+ // even for i686-pc-win32 targets.
+ Builder.defineMacro("__weak", "__attribute__((objc_gc(weak)))");
}
};
} // end anonymous namespace
diff --git a/clang/test/Rewriter/rewrite-weak-attr.m b/clang/test/Rewriter/rewrite-weak-attr.m
new file mode 100644
index 00000000000..2e559ee3e32
--- /dev/null
+++ b/clang/test/Rewriter/rewrite-weak-attr.m
@@ -0,0 +1,13 @@
+// RUN: %clang_cc1 -triple i686-pc-win32 -fms-extensions -fblocks -Dnil=0 -rewrite-objc -o - %s
+int main() {
+ __weak __block id foo = nil;
+ __block id foo2 = nil;
+ id foo3 = nil;
+
+ void (^myblock)() = ^{
+ foo = nil;
+ foo2 = nil;
+ [foo3 bar];
+ id foo4 = foo3;
+ };
+}
OpenPOWER on IntegriCloud