iOS Build Environment Help Center

CocoaPods: Linking FirebaseABTesting... Undefined symbols for architecture arm64

append delete Mazing Labs

:: My Configs

• Windows 10
• Builder version 3.51
• iOS SDK version 15.0

:: Problem

In my project, I use these Firebase v8.9.0 plugins - RemoteConfig, Messaging, Analytics, Crashlytics.
When I build my project without CocoaPods everything is fine. When I try to build with Cocoa, this happens:

%
Building the CocoaPods dependency project FirebaseABTesting...
 + Preparing output directory...
   + XCFrameworks: 6 supplied
   + Libraries: 10 supplied, 0 built
   + Frameworks: 2 supplied, 6 built
 + Pre-parsing project files...
 + Building FirebaseABTesting for iphoneos (configuration: Release)
   + [arm64] Pods/FirebaseABTesting/FirebaseABTesting/Sources/ABTConditionalUserPropertyController.m.obj is up to date
   + [arm64] Pods/FirebaseABTesting/FirebaseABTesting/Sources/ABTExperimentPayload.m.obj is up to date
   + [arm64] Pods/FirebaseABTesting/../Target Support Files/FirebaseABTesting/FirebaseABTesting-dummy.m.obj is up to date
   + [arm64] Pods/FirebaseABTesting/FirebaseABTesting/Sources/FIRExperimentController.m.obj is up to date
   + [arm64] Pods/FirebaseABTesting/FirebaseABTesting/Sources/FIRLifecycleEvents.m.obj is up to date
   + [arm64] Linking FirebaseABTesting...
Undefined symbols for architecture arm64:
  "_GULLoggerForceDebug", referenced from:
      ___FIRLoggerInitializeASL_block_invoke in FirebaseCore(FIRLogger.o)
  "_GULLoggerEnableSTDERR", referenced from:
      ___FIRLoggerInitializeASL_block_invoke in FirebaseCore(FIRLogger.o)
  "_GULLoggerInitializeASL", referenced from:
      ___FIRLoggerInitializeASL_block_invoke in FirebaseCore(FIRLogger.o)
  "_GULLoggerRegisterVersion", referenced from:
      ___FIRLoggerInitializeASL_block_invoke in FirebaseCore(FIRLogger.o)
  "_GULLogBasic", referenced from:
      _FIRLogBasic in FirebaseCore(FIRLogger.o)
  "_GULSetLoggerLevel", referenced from:
      _FIRSetLoggerLevel in FirebaseCore(FIRLogger.o)
  "_GULIsLoggableLevel", referenced from:
      _FIRIsLoggableLevel in FirebaseCore(FIRLogger.o)
  "_OBJC_CLASS_$_GULAppEnvironmentUtil", referenced from:
      objc-class-ref in FirebaseCore(FIRApp.o)
      objc-class-ref in FirebaseCore(FIRBundleUtil.o)
      objc-class-ref in FirebaseCore(FIRFirebaseUserAgent.o)
ld: 8 symbol(s) not found for architecture arm64
%

It is something wrong with Cocoa or with my project?

Reply RSS

Replies

append delete #1. Pierre-Marie Baty

Hello

Unsure here. It looks like (by their GU… prefix) symbols from the GoogleUtilities framework. Was this framework downloaded by CocoaPods ?

append delete #2. Mazing Labs

Yes, it was downloaded. Here is my console output:

%
========================== CocoaPods output BEGIN ===========================
Analyzing dependencies
Adding spec repo `trunk` with CDN `https://cdn.cocoapods.org/`
Downloading dependencies
Installing AppsFlyerFramework (6.5.4)
Installing Firebase (8.13.0)
Installing FirebaseABTesting (8.15.0)
Installing FirebaseAnalytics (8.13.0)
Installing FirebaseCore (8.13.0)
Installing FirebaseCoreDiagnostics (8.15.0)
Installing FirebaseCrashlytics (8.13.0)
Installing FirebaseInstallations (8.15.0)
Installing FirebaseMessaging (8.13.0)
Installing FirebaseRemoteConfig (8.13.0)
Installing Google-Mobile-Ads-SDK (9.6.0)
Installing GoogleAppMeasurement (8.13.0)
Installing GoogleDataTransport (9.1.4)
Installing GoogleUserMessagingPlatform (2.0.0)
Installing GoogleUtilities (7.7.0)
Installing PromisesObjC (2.1.1)
Installing nanopb (2.30908.0)
Generating Pods project
Integrating client project
%
append delete #3. Pierre-Marie Baty

Would you mind sharing that Xcode project with me so that I have a closer look ? Please send the link to my email address. You can remove the "build" and "Pods" directories to save space.

append delete #4. Mazing Labs

Ok, I will do it some later.

append delete #5. Pierre-Marie Baty

Have you sent me anything yet ? Or was the problem solved otherwise ?

append delete #6. Mazing Labs

I sent it just now. Sorry, took some time to do it.

append delete #7. Mazing Labs

I updated my iOS SDK version to 15.5.

In xcode project that I sent you, I forgot to disable Appodeal plugin, and there is another problem with it, which I wanted to deal with later, but it seems, I must describe it now.
At start of CocoaPods, Appodeal repo is cloning:

%
Cloning spec repo `appodeal-cocoapods` from `https://github.com/appodeal/CocoaPods.git`
%

It's ok, but then cocoa finds a lot of multiple specifications, like this:

%
[!] Found multiple specifications for `APDAppLovinAdapter (3.0.0.1)`:
- /Users/cocoapods/.cocoapods/repos/trunk/Specs/a/c/2/APDAppLovinAdapter/3.0.0.1/APDAppLovinAdapter.podspec.json
- /Users/cocoapods/.cocoapods/repos/appodeal-cocoapods/APDAppLovinAdapter/3.0.0.1/APDAppLovinAdapter.podspec.json
%

I'm not specialist in CocoaPods and I don't understand, why it happens.

Also, there is another little problem, with Firebase Remote Config - cocoa can't find compatible version, and it is too related to the Appodeal plugin, because APDFirebaseAdapter is one of Appodeal's adapter:

%
[!] CocoaPods could not find compatible versions for pod "Firebase/RemoteConfig":
  In Podfile:
    APDFirebaseAdapter (= 3.0.0.1) was resolved to 3.0.0.1, which depends on
      Firebase/RemoteConfig (~> 8.15.0)

    Firebase/RemoteConfig (= 8.13.0)
%
append delete #8. Pierre-Marie Baty

CocoaPods doesn't finish successfully. That explains why your build doesn't either.

Given the exact same Podfile, does CocoaPods behave identically on macOS ? If yes, it's a CocoaPods problem. If not, there's a problem with the builder. Please do the test.

append delete #9. Mazing Labs

I tested it on macOS. CocoaPod's behaviour is same. Unfortunately, it's realy a CocoaPods problem. I will try to talk with Appodeal's support, maybe they know, how to fix it.

append delete #10. Pierre-Marie Baty

Yes, that's the thing to do.

Good luck,

append delete #11. Mazing Labs

I found a temporary solution - I removed Firebase dependencies from pod file, which had different version than Appodeal's plugin dependencies. It's not final, I will need to synchronize versions of Firebase in project and firebase in cocoa for Appodeal. Anyway, Cocoa finished successfully, and builder started building project, but then builder showed this:

%
 + [arm64] Compiling Pods/CriteoPublisherSdk/CriteoPublisherSdk/Sources/SKAdNetwork/SKAdNetworkInfo.swift...
error: your project contains code written in the Swift language, but the Swift compiler hasn't been ported to Windows yet.
Possible workarounds:
 - If this source file is part of a third-party dependency, look for an Objective-C/C++ only version of that dependency and use it instead.
 - If this source file is part of your project itself, rewrite it in C, C++, Objective-C or Objective-C++.
%

It seemed to me, builder already has some undocumented tools to build swift code, but they are not integrated in final build script. So, how to use them to build .swift files or it is not possible right now?=)

append delete #12. Pierre-Marie Baty

Properly integrating the Swift compiler (swiftc) in the build script requires more time and testing than I can afford at the moment. It was one of my goals at a time there was a big need for it, but these initial circumstances changed:

The fact is that now, almost all third-party SDKs provide precompiled binaries as an alternative to CocoaPods, that you can download on their creator's website. This not only has the big advantage of providing much better build time, but it also eliminates the need to compile Swift code at all as far as Unity projects are concerned. Consequently, I stopped my work on this task, until the need grows again and I can afford enough time to finish it.

That is why, as you noticed, I recommend in my documentation to not use CocoaPods and prefer precompiled binaries everywhere it's possible.

If you can't get the precompiled binary for the asset you need and/or would like to investigate the Swift route nonetheless, the tools are here for you if you're knowledgeable enough to know how to call them on the command line, but please remember that I haven't tested them. I'd be nonetheless interested in reading the results of your experiments !

append delete #13. Mazing Labs

It would be interesting for me solve this problem and do some experiments, but I will not make any promises that I will be able to do this in the near future for the same reason of lack of time and because I have always been far from subtleties of Apple technology.

append delete #14. Pierre-Marie Baty

No problem. The Swift compiler will be integrated someday eventually :)

Reply

(Leave this as-is, it’s a trap!)

There is no need to “register”, just enter the same name + password of your choice every time.

Pro tip: Use markup to add links, quotes and more.

Moderators: Pierre-Marie Baty