Xcode 7.3 cannot create __weak reference in file using manual reference counting

Objective CXcodeCocoapods

Objective C Problem Overview


After updating to Xcode 7.3, it throws the error Cannot create __weak reference in file using manual reference counting in pod files. Has anyone solved this issue?

Objective C Solutions


Solution 1 - Objective C

Set Build Settings -> Apple LLVM 7.1 - Language - Objective C -> Weak References in Manual Retain Release to YES.

Visual example

Taken from Apple Developers Forums - Xcode 7.3b4, non-arc, cannot create __weak reference.

Solution 2 - Objective C

This is official answer from Apple from the link:

> This issue behaves as intended based on the following: We are in the > process of implementing weak references in all Objective-C language > modes. Since “__weak” has historically been ignored in non-ARC (and > non-GC) language modes, we’ve added this error to point out places > where the semantics will change in the future. Please update your bug > report to let us know if this is still an issue for you.

So basically, if you are using Pod for 3rd party libraries, you have to either delete __weak in non-ARC or wait for update.

Update @ 3/23

I should've research more about flags that I can pass to complier in order to bypass these kinda stuffs. But fundamentally you should not use __weak in non-ARC mode from now to avoid any unexpected conflicts. For cocoapods users, you do not need to delete __weak or wait for update but set Weak References in Manual Retain Release flag in build settings to YES like Lean said. Hope this help.

Solution 3 - Objective C

The best way to solve this is to add a post_install script to your Podfile that sets the Weak References in Manual Retain Release flag to yes in all your pod targets. To do that just paste the following code at the bottom of your Podfile.

post_install do |installer_representation|
    installer_representation.pods_project.targets.each do |target|
        target.build_configurations.each do |config|
            config.build_settings['CLANG_ENABLE_OBJC_WEAK'] ||= 'YES'
        end
    end
end

Sometimes, doing that result in the error -fobjc-weak is not supported on the current deployment target. You can solve that by adding another configuration option, forcing all the pods to target the version you want (based on this answer):

post_install do |installer_representation|
    installer_representation.pods_project.targets.each do |target|
        target.build_configurations.each do |config|
            config.build_settings['CLANG_ENABLE_OBJC_WEAK'] ||= 'YES'
            config.build_settings['IPHONEOS_DEPLOYMENT_TARGET'] = '9.3'
        end
    end
end

Solution 4 - Objective C

Workaround for Facebook weak references in FBSettings.m

To Podfile, it is possible to write a script to run after the pod install / update, describes the following there.

  
post_install do | installer |
classy_pods_target = installer.pods_project.targets.find {| target | target.name == 'Facebook-iOS-SDK'}
classy_pods_target.build_configurations.each do | config |
config.build_settings['CLANG_ENABLE_OBJC_WEAK'] ||= 'YES'
end
end

CLANG_ENABLE_OBJC_WEAK how to find the words of the magic that. Valid XHTML.

Solution 5 - Objective C

I have found this.

I guess it's meant delete __weak

https://forums.developer.apple.com/thread/38934

> Erm, was there ever such a thing as a weak variable reference under MRR [manual retain-release]? "__weak" means one or both of two things: > > 1. An unowned reference (i.e. not representing a retain count). > > 2. A zeroing reference (i.e. that the runtime zeroes when the referenced object is deallocated). > > #1 doesn't apply to MRR, because you just don't retain the variable anyway. > > #2 doesn't apply to MRR either, because the runtime support is in GC and ARC [automatic reference counting], which you're not using. > > It sounds like the compiler is now just complaining that it can't do what it could never do. (And in the case of an app delegate, you wouldn't be able to tell the difference at run-time, since the app delegate generally is never deallocated.)

Solution 6 - Objective C

Just goto your target in "Build Phases" tab look for the pod files in "Compile Sources", click those files and add compiler flag "-fobjc-arc"

Solution 7 - Objective C

Or change __weak to __unsafeunretained. This will solve the problem in tradition. Since MRC (before xCode 4 --) __weak was not in iOS.

Attributions

All content for this solution is sourced from the original question on Stackoverflow.

The content on this page is licensed under the Attribution-ShareAlike 4.0 International (CC BY-SA 4.0) license.

Content TypeOriginal AuthorOriginal Content on Stackoverflow
QuestionREALFREE View Question on Stackoverflow
Solution 1 - Objective CRyanView Answer on Stackoverflow
Solution 2 - Objective CREALFREE View Answer on Stackoverflow
Solution 3 - Objective Cvilly393View Answer on Stackoverflow
Solution 4 - Objective CManobalaView Answer on Stackoverflow
Solution 5 - Objective ClackView Answer on Stackoverflow
Solution 6 - Objective CpeskiView Answer on Stackoverflow
Solution 7 - Objective Cuser3693546View Answer on Stackoverflow