Xcode 7.3 cannot create __weak reference in file u

2019-01-21 01:12发布

问题:

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?

回答1:

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

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



回答2:

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.



回答3:

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


回答4:

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. .



回答5:

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.)



回答6:

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"



回答7:

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