From: Chris Lattner Date: Tue, 7 Apr 2009 16:50:40 +0000 (+0000) Subject: Fariborz points out that weak is now defined to the attribute even X-Git-Url: https://granicus.if.org/sourcecode?a=commitdiff_plain;h=10d2427386124b69c150bef0163b525404bbb545;p=clang Fariborz points out that weak is now defined to the attribute even in C mode. git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@68520 91177308-0d34-0410-b5e6-96231b3b80d8 --- diff --git a/lib/Basic/Targets.cpp b/lib/Basic/Targets.cpp index 5fa2967e59..2197b42eb7 100644 --- a/lib/Basic/Targets.cpp +++ b/lib/Basic/Targets.cpp @@ -144,14 +144,14 @@ static void getDarwinDefines(std::vector &Defs, const LangOptions &Opts, Define(Defs, "__MACH__"); Define(Defs, "OBJC_NEW_PROPERTIES"); - // Darwin defines __weak and __strong even in C mode. - if (!Opts.ObjC1 || Opts.getGCMode() == LangOptions::NonGC) { - Define(Defs, "__weak", ""); + // __weak is always defined, for use in blocks and with objc pointers. + Define(Defs, "__weak", "__attribute__((objc_gc(weak)))"); + + // Darwin defines __strong even in C mode (just to nothing). + if (!Opts.ObjC1 || Opts.getGCMode() == LangOptions::NonGC) Define(Defs, "__strong", ""); - } else { - Define(Defs, "__weak", "__attribute__((objc_gc(weak)))"); + else Define(Defs, "__strong", "__attribute__((objc_gc(strong)))"); - } // FIXME: OBJC_ZEROCOST_EXCEPTIONS when using zero cost eh.