iOS Build Environment Help Center

errors building with cocoa pods daemon and firebase

append delete RobReijnen

windows:10
builder:3.54
ios: 16.2
https://pastebin.com/WJxgB6kb

Hi Pierre-Mary,

I'm getting the following errors when attempting to create a build. I've been looking on different threads but I 'm not able to figure it out.

I am using your cocoa daemon but I've also tried to add the frameworks manually. Unfortunately, I didn't get it to work.

My project is using firebase messaging.

Could you help me out?

(I am sending my xcode project to your email by wetransfer, if that helps. )

Reply RSS

Replies

append delete #1. Pierre-Marie Baty

Hello

I received the Xcode project and I'm looking at it right now.

append delete #2. Raad

hey.
i have same error,
i hope it easy to fix :)

thanks pierre-marie for your help <33

append delete #3. Raad

hey
any update on this?

append delete #4. Pierre-Marie Baty

One of the Pods involved in the operation is built (in compliance with the informations from the pod itself !) in a directory that doesn't match the library and framework search directory that's passed by the pod to the linker.

I'm still investigating why it's able to work with Xcode. That's still a mystery to me. It looks like Xcode may decide for a build directory that would contradict the pod's instructions. If I can't find the right reason, the workaround will be to pass more directories to the linker than those explicitly given by the pod.

#5. Raad

This post was deleted by its owner

append delete #6. Raad

heyy Pierre
thank you so much.
i hope it will be easy on you :)
take your time.

but really your tools so amazing <3.

append delete #7. RobReijnen

Hi,

Thank you very much for looking!

Is that workaround something I can do on my end? And if so, could you instruct me how to do it?

append delete #8. Pierre-Marie Baty

That would be something like adding the following linker flags:

%
-Fbuild/Release-iphoneos/FBLPromises -framework Security
%

The first one to "fix" the framework path to the Promises pod build directory, the second one to bring in the Security framework from the iOS SDK that is implicitly linked.

I haven't tested, so let me know if it helps.

append delete #9. Raad

hey.
i tested it but got same errors.

append delete #10. Oneday

Hello,

I've just installed Appodeal and I've been getting issues that are similar to the ones above.

Here's the pastebin for reference: https://pastebin.com/527H8K9i
(Builder 3.54 & SDK 16.2)

I'm not sure if it's caused by the same issue or not, let me know if I should make a new post instead.

append delete #11. Raad

Hello,
is there a different way to make it work?

append delete #12. RobReijnen

Hi,

For me this also isn't working. Please let me know if there are other ways, we kind of depend on the firebase functionality for our product.

append delete #13. Pierre-Marie Baty

@Oneday : same issue indeed.

I'm still looking at it. Can't find *why* Xcode can build this, as required frameworks are missing from the project files. It's as if Xcode added framework specifications by its own will.

:: @Pierre-Marie Baty added on 23 Feb ’23 · 10:19

@all: another workaround is to remove the Firebase pods from the Podfile and inject the Firebase frameworks from the Firebase binary release manually:

https://github.com/firebase/firebase-ios-sdk/releases

Make sure to fetch a version that's compatible with what the Podfile says. e.g. if you have

%Podfile
target 'UnityFramework' do
  pod 'Firebase/Core', '10.4.0'
  pod 'Firebase/Messaging', '10.4.0'
end
%

then get the binary release labeled *Firebase Apple 10.4.0*.

append delete #14. Raad

hey,

i have been trying this many times , but i still cant make it work.
in my Podfile

%Podfile
target 'UnityFramework' do
  pod 'Google-Mobile-Ads-SDK', '~> 9.11'
end
target 'Unity-iPhone' do
end
%

so i download Google-Mobile-Ads-SDK 9.11 , and put it in Pods folder
but still same error :((
or am i doing it wrong?
tho in The Builder settings i unchecked the Always Rebuild, so it wont redownload same old Pods.
idk but as i see it show sth -wrong- with the GoogleUtilities >> Environment.

append delete #15. Pierre-Marie Baty

Yes, you're doing it wrong.

It doesn't work that way. Please *read the documentation* on how to integrate third-party frameworks. Basically, you need to use the "Add extra framework" button for that - and of course, follow Google's integration guidelines.

append delete #16. Oneday

Thanks for taking the time to look into it.

I've added all of the frameworks provided by Appodeal manually with the Add Framework button, and removing them from the podfile. Regarding this, I would make a suggestion to allow us to add more than 1 framework at once. The selection window is extremely tiny and it made this step very tedious, since there were many frameworks to add.

It does seem to be getting further along in the build process, but I'm now getting stuck here:

https://pastebin.com/ywQUPWiX

I've tried adding this "CoreTelephony" frameworks manually, navigating in the iOS SDK folder to find it. Unfortunately, it didn't work and I'm still getting the same error. I did notice that when I added this last framework, it only changed the "Extra Linker Flag" box, adding "-framework CoreTelephony". Nothing was added to the "Extra Compiler Flag" box.l

append delete #17. Pierre-Marie Baty

@Oneday - the error happens when building the GoogleUtilities pod. Probably part of either Firebase or Google Mobile Ads. Remove these Pods from your Podfile and add them manually.

append delete #18. Raad

hey,
i did it as u told me , but i got this new error.
https://mega.nz/file/qGoGCCqa#prv63nyXcnEq_UtpGiy-oPzxxrdze1JO4p4tbiPQpLY

append delete #19. Pierre-Marie Baty

@Raad: your error looks like this one : https://www.pmbaty.com/iosbuildenv/help/thread.php?path=Problem%20solving/&file=errors-compiling-an-admob-project
Please follow the same procedure to ascertain that your project is buildable first.

append delete #20. Oneday

Hi again,

The Appodeal SDK contains a lot of frameworks, including the following:

pod 'APDAppLovinAdapter', '3.0.2.1'
pod 'APDAppsFlyerAdapter', '3.0.2.1'
pod 'APDBidMachineAdapter', '3.0.2.1'
pod 'APDFacebookAdapter', '3.0.2.1'
pod 'APDGoogleAdMobAdapter', '3.0.2.1'
pod 'APDIABAdapter', '3.0.2.1'
pod 'APDIronSourceAdapter', '3.0.2.1'
pod 'APDMetaAudienceNetworkAdapter', '3.0.2.1'
pod 'APDMyTargetAdapter', '3.0.2.1'
pod 'APDStackAnalyticsAdapter', '3.0.2.1'
pod 'APDUnityAdapter', '3.0.2.1'
pod 'APDVungleAdapter', '3.0.2.1'
pod 'APDYandexAdapter', '3.0.2.1'

I suspect that these are wrappers for other frameworks. In appodeal's documentation, they do tell us to add these frameworks (alongside all the others) in order to build the app properly.

When trying to add these via the project builder, I get the following error message: "This .xcframework directory doesn't seem to support the platform (iOS) and/or architecture(s) for which you are building.", so I can't seem to be able to use the workaround.

Thank you again for your time and continued support.

append delete #21. Pierre-Marie Baty

Maybe you downloaded the Appodeal SDK for macOS and there is a different download for iOS ? If you give me the link to their download page I can perhaps locate it for you.

append delete #22. Oneday

Hello,

I downloaded the Unity Plugin from the following page: https://wiki.appodeal.com/en/unity/get-started

This version didn't mention importing frameworks manually, I assume it was meant to work with cocoapods.

From this page: https://wiki.appodeal.com/en/ios/get-started, I was able to grab the SDK and the frameworks. In Step 1, choose "manual" versions rather than "cocoapods", to get the download link for the SDK as well as the list of all the frameworks.

append delete #23. Oneday

Update:

I've deleted appodeal and replaced it with IronSource. I figured since it's the "official" Unity Ad network now, it's the least likely to cause issues, and at this point I just want the build to work.

I've updated to 3.55 and I now get further into the build process. When linking UnityFramework, I'm getting a Swift duplicate error.

ld64.lld: error: duplicate symbol: _swiftoverride_class_getSuperclass(swift::TargetMetadata<swift::InProcess> const*)
>>> defined in D:/Programs/iOS Project Builder for Unity/SDK/../Toolchain/extra\libswiftCompatibilityMissingSymbols.a(swiftCompatibilityMissingSymbols.arm64.o)
>>> defined in D:/Programs/iOS Project Builder for Unity/SDK\libswiftCompatibility51.a(ProtocolConformance.cpp.o)

(Full log: https://pastebin.com/hVJHud0U)

I imagine I need to get rid of one of these file but deleting either of them seems to break the build right at the beginning.

append delete #24. Pierre-Marie Baty

@Oneday: this specific issue should be handled by the build script. It means something needs to be fixed on my side. Could you please send me your Xcode project to my email address (pm at this domain) so that I reproduce the problem ? Thanks in advance.

About Appodeal, your 2nd link was the right one, but it looks like they goofed on their side and swapped the iOS Appodeal SDK with the Mac Appodeal SDK (since the builder couldn't find any iOS frameworks in it).

append delete #25. Oneday

Oh, that's unfortunate that they made such a mistake. I'm sending the project over now.

append delete #26. Pierre-Marie Baty

I'm not saying they did (someone would have to verify the binaries), I'm just saying it looks like so. I'll look at your project now.

append delete #27. Oneday

Hi again,

Is there any update about this? Or is there a workaround I can do on my end to avoid the duplication error?

Thanks again

append delete #28. Raad

hello,

any update?
i hope u gonna find the way to fix it :(

thank you.

append delete #29. Pierre-Marie Baty

@Oneday: I could build your project with minor fixes.

Step 1: edit build.cmd around line 2385 and change the line that says:

% build.cmd circa line 2385
				set LDFLAGS_DEFAULTLIBS=!LDFLAGS_DEFAULTLIBS! -L/usr/lib/swift -L"!SDK_PATH!/../Toolchain/extra" -lswiftCompatibilityMissingSymbols
%

into

% build.cmd circa line 2385
				set LDFLAGS_DEFAULTLIBS=!LDFLAGS_DEFAULTLIBS! -L/usr/lib/swift
				if not exist "!SDK_PATH!\libswiftCompatibility51.a" set LDFLAGS_DEFAULTLIBS=!LDFLAGS_DEFAULTLIBS! -L"!SDK_PATH!/../Toolchain/extra" -lswiftCompatibilityMissingSymbols
%

Step 2: add "-framework GoogleMobileAds" in the extra linker flags field of the *main application* (Main app) tab (NOT the UnityFramework tab).

After these fixes your project builds successfully. I haven't tested it on a real device though.

@Raad: Are you sure your project is error-free first ? Can Xcode build it ?

append delete #30. RobReijnen

Hi Pierre-Marie,

I have yet to succeed using your workaround. Have you tested your proposed workaround with my project? Where you able to build it? I can't seem to figure out what I'm doing wrong.

append delete #31. Oneday

Hello Pierre-Marie,

The workaround worked for me, I was able to make a build! Thanks a lot.

append delete #32. Pierre-Marie Baty

@RobReijnen: some of the Pods your project uses (e.g. FirebaseCoreInternal, part of the FirebaseCore framework) are at least partly written in Swift and not in C/C++/Objective-C. This builder doesn't compile Swift code (at least at the moment). To work this around and build your project, you need to use the precompiled version of these frameworks, which can usually be downloaded from their vendor's website or GitHub. For Google Firebase, the builder's HTML documentation gives detailed directions, with download links. Have you followed these instructions ? If so, on what specific part do you need help ?

append delete #33. RobReijnen

Hi,

Thank you a lot! For some reason it just didn't click in my head what the problem and solution was. I am finally able to build now. Only my builds are now crashing on startup (without firebase it is working).

The debug console is giving me the same error as in this post:
https://stackoverflow.com/questions/62982402/unity-xcode-build-fails-because-of-unityframework-library-not-loaded

So this seems fixable in xcode. But I don't understand how to do it in your builder.

I am also getting a lot of warnings now while building:
https://pastebin.com/QkmHsmdj

Is this still part of my previous problem, or is this something else?

append delete #34. Raad

Heyy

when i try to build using ES mobile ads
https://mega.nz/file/jDwCULab#ASG3JCVGcS2pDXQg5bKIXLnN6eHAM29HPYwuJHtFdlY
i got this error.

but when i change it and use MobileTools
https://mega.nz/file/qXIAgTYT#vUpzqXzqm1OBY0cvnFkNqsINgKjcfQCckMyL7yUcIYM

it build and the app show up in my phone but it crash at startup.

append delete #35. Pierre-Marie Baty

The warnings you have means something must be fixed on my side in dsymutil. They affect the debug database only. If you uncheck the dSYM checkbox in the builder UI they’ll go away.

The error you get in the debug console means some necessary frameworks aren’t included by the build script in your app. This happens because these frameworks are loaded explicitly at runtime by a call to dlopen() in the code and not at loading time, so they haven’t been detected by the build script. To fix this you need to copy them yourself in the Frameworks directory of your app using a pre-packaging script. The error mentions the FBLPromises framework, but there might be others.

append delete #36. RobReijnen

Hi, Thank you! I have finally been able to get my build running with firebase. I'm still not actually getting my push notifications but that's another issue. I really appreciate your help! Thank you!

append delete #37. Pierre-Marie Baty

Glad to hear you got it working. You’re welcome.

append delete #38. Raad

still cant make it work

append delete #39. Pierre-Marie Baty

@Raad:

You have 2 different build contexts here.

1. Your problem with ES mobile ads : the LLVM linker (LLD) doesn't allow duplicate symbols, whereas the Apple one does - see https://github.com/llvm/llvm-project/issues/55893 . Use the Apple linker to link with ES mobile ads (or tell the ES mobile ads developers that they have duplicate symbols and that it's a mistake that should be fixed anyway.)

2. Your problem with MobileTools : well, what does the remote debug console say for the reason of the crash ?

append delete #40. Raad

heyy,

thank you it works now <3

i tried to upload to app store
i got this error.
if u have any idea on that.

ITMS-90161: Invalid Provisioning Profile - The provisioning profile included in the bundle com.raadgames.d*** [Payload/ProductName.app] is invalid. [Missing code-signing certificate]. A Distribution Provisioning profile should be used when submitting apps to the App Store. For more information, visit the iOS Developer Portal.

append delete #41. Pierre-Marie Baty

Are you sure you signed the app you’re trying to upload with a *distribution* certificate and a provisioning profile suitable for App Store uploads ?

append delete #42. Raad

yes,

i have been testing for a week now.
i always got same error message.

but i tried it on mac , and uploaded without any problem.

append delete #43. Pierre-Marie Baty

Then it is possible that you tried to upload an app signed with a revoked certificate.

To make sure your certificates and profiles are the right ones, delete them from the Keychain tool and download them all again from the iOS provisioning portal.

append delete #44. Raad

Omg thank you so much it works!
<3

append delete #45. Pierre-Marie Baty

You’re welcome. Happy testing !

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