upgrade-support: Solution: Upgrading from 0.61.5 to 0.62.0 "Undefined symbol: _swift_getFunctionReplacement"
Environment
System:
OS: macOS 10.15.3
CPU: (12) x64 Intel(R) Core(TM) i7-8750H CPU @ 2.20GHz
Memory: 123.51 MB / 16.00 GB
Shell: 3.2.57 - /bin/bash
Binaries:
Node: 12.14.0 - /usr/local/bin/node
Yarn: 1.22.4 - /usr/local/bin/yarn
npm: 6.13.4 - /usr/local/bin/npm
Watchman: 4.9.0 - /usr/local/bin/watchman
SDKs:
iOS SDK:
Platforms: iOS 13.4, DriverKit 19.0, macOS 10.15, tvOS 13.4, watchOS 6.2
Android SDK:
API Levels: 23, 25, 26, 27, 28, 29
Build Tools: 23.0.1, 25.0.3, 26.0.1, 27.0.3, 28.0.3, 29.0.0
System Images: android-19 | ARM EABI v7a, android-19 | Google APIs ARM EABI v7a, android-27 | Google APIs Intel x86 Atom, android-27 | Google Play Intel x86 Atom, android-28 | Google Play Intel x86 Atom, android-29 | Google APIs Intel x86 Atom
IDEs:
Android Studio: 3.4 AI-183.6156.11.34.5522156
Xcode: 11.4/11E146 - /usr/bin/xcodebuild
npmPackages:
react: 16.11.0 => 16.11.0
react-native: 0.62.0 => 0.62.0
npmGlobalPackages:
react-native-clean-project: 3.2.4
react-native-cli: 2.0.1
react-native-create-library: 3.1.2
react-native-template-typescript: 5.2.0
react-native: 0.60.4
Upgrading version
Upgrading from 0.61.5 to 0.62.0
Problem
Initial upgrade steps
-
I started by following the 0.61.5 to 0.62.0 RN upgrade helper. I performed all the changes shown in the diffs from the upgrade helper tool.
-
For the
project.pbxproj
changes, I proceeded to follow all four steps in the React Native 0.62 upgrade explanation in this repo.
I encountered the following errors when attempting to build iOS
Showing All Errors Only
Undefined symbol: _swift_getFunctionReplacement
Undefined symbol: _swift_getOrigOfReplaceable
More detailed error
Undefined symbols for architecture x86_64:
"_swift_getFunctionReplacement", referenced from:
_swift_getFunctionReplacement50 in libswiftCompatibilityDynamicReplacements.a(DynamicReplaceable.cpp.o)
(maybe you meant: _swift_getFunctionReplacement50)
"_swift_getOrigOfReplaceable", referenced from:
_swift_getOrigOfReplaceable50 in libswiftCompatibilityDynamicReplacements.a(DynamicReplaceable.cpp.o)
(maybe you meant: _swift_getOrigOfReplaceable50)
ld: symbol(s) not found for architecture x86_64
clang: error: linker command failed with exit code 1 (use -v to see invocation)
I found that some folks with the same error details in this issue thread from TelegramMessenger (completely unrelated to my app) but they seemed to find a solution by enabling dead code stripping.
I enabled Dead Code Stripping in Build Settings for DEBUG in EACH target of my project (we have 4). Dead code stripping was already enabled in the release configuration for all the targets and in the project build settings/
After enabling dead code stripping, I was able to build but the app would crash immediately with the following error
This copy of libswiftCore.dylib requires an OS version prior to 12.2.0
In order to fix this, I followed the steps in this SO answer, namely:
- Added a
Dummy.swift
file to the project (I already had bridging header files from following the steps in issue #13 of this repo. - Set
Always Embed Swift Standard Libraries
toYES
in the build settings for my project and all my targets.
Solution
So in summary, my complete upgrade steps were
-
Follow the 0.61.5 to 0.62.0 RN upgrade helper.
-
For the
project.pbxproj
changes, follow all four steps in the React Native 0.62 upgrade explanation in this repo. -
Enable Dead Code Stripping in Build Settings for both debug and release in each project target
-
Set
Always Embed Swift Standard Libraries
toYES
in the build settings for my project and all my targets. -
Either add a
Dummy.swift
file to the project, or don’t delete the dummy swift file that you created in step 2 (the issue #13 in this repo).
About this issue
- Original URL
- State: open
- Created 4 years ago
- Reactions: 233
- Comments: 31
Commits related to this issue
- ⬆️ react-native 0.62.2 $ react-native upgrade + lots of manual changes @ref: - https://react-native-community.github.io/upgrade-helper/?from=0.61.5&to=0.62.2 - https://github.com/react-native-commun... — committed to bramus/react-native-maps-directions-example by bramus 4 years ago
- Build Fix Bug fix for "Undefined symbol: _swift_getFunctionReplacement" https://github.com/react-native-community/upgrade-support/issues/25 — committed to CruGlobal/voke-react-native by deleted user 3 years ago
Following the SOLUTIONS in the topic works for me, just one thing:
Enable Dead Code Stripping --> This needed to be done for the TARGETS level, not PROJECT level
setting DEAD_CODE_STRIPPING to TRUE solved it for me 🙏
I managed to solve this issue just a few moments, ago. For me the problem was I entered the library search paths with quotes (") like so:
opposed to
and followed the rest of the guides in #13
@chestercharles ur solution in addition of
1- setting FB_SONARKIT_ENABLED=1
2- include /usr/lib/swift into Linking -> runpath search path , Also, for the record, after I built my app, it crashed on launch with Thread 1: signal SIGABRT Searching a bit deeper, I found this message: This copy of libswiftCore.dylib requires an OS version prior to 12.2.0. I added a File.swift in my projects, and it was ok. But if I removed the file again, it crashed again. So, in xCode, I went to BuildSettings -> Linking -> runpath search path , and manually changed each build line to:
both those step with yours managed to make it work PS the above fixes where from other issue here and no credits goes to me
I did these steps from React Native 0.62 upgrade (Xcode) and set to
project.pbxproj
the following configs:Change this:
To this:
Remove
DEAD_CODE_STRIPPING
and addENABLE_BITCODE = NO
.And it worked fine! 🚀
It works after I set “Don’t Dead Strip Inits and Terms” to “Yes”
This is very important. I had been setting on Project level and wasting my time. Thanks @ptgamr.
@AlexandrDobrovolskiy I had a problem where I set
DEBUG
macro to false after following https://github.com/react-native-community/upgrade-support/issues/25#issuecomment-608585271.If you’re like me and new to Xcode, this instruction might not be clear enough. Here’s a screenshot of the correct config:
The key is the
$(inherited)
so we don’t loseDEBUG=1
😃After I implemented the solution, I kept getting the “No bundle url present” error. To fix it, I had to select my project -> select Build Settings -> Deployment (iOS) -> Strip Debug Symbols during Copy -> Set Debug to Yes. The reason is that in AppDelegate.m you have this piece of code:
In my case, since DEBUG was false, React Native was looking for a main.jsbundle file. After I set Debug to “Yes”, the error disappeared and my app ran without any issues.
I followed both the OP instructions and I’ve added FB_SONARKIT and LD_RUNPATH_SEARCH_PATHS AND it worked 🎉
Then I dug into the changes and realised that we don’t need the dummy file, it just looks that way because when you add it, it sets
Always Embed Swift Standard Libraries
toYES
, and when you remove it, it sets it toNO
😁 So you can delete it, just revert the 2 lines that relate toAlways Embed...
OR re-added them as the OP did in step 4 - the same goes forFB_SONARKIT_ENABLED
, which should be added automatically, but sometimes isn’t 😁The rest of the changes are needed, as described in Setting up Flipper for iOS and Troubleshooting - since these are listed under setting up Flipper, I think they must be added to the original guide since I don’t see how anything can work if you don’t do them 😁 @pvinis?
Edit: I didn’t notice I was getting a warning:
but managed to fix it.
I have updated the react-native version 0.61.5 to 0.63.3 and I am also facing the below issue.
Undefined symbol: _swift_getFunctionReplacement
Undefined symbol: _swift_getOrigOfReplaceable
I tried the above solution but none of the solutions work for me.
Today I did something that I was hesitating a little bit but worked, I just created a new project and copy and paste everything from the old one, now it is working.
Instructions on how to manually add Flipper 0.62+ on Flipper site vs upgrade-support repo are pretty different. Check https://fbflipper.com/docs/getting-started/react-native-ios . Shouldn’t we point to Flipper site to follow react native instructions?
The troubleshooting page https://fbflipper.com/docs/troubleshooting/ covers most of the solutions mentioned here
I also had a few problems with android
Problem 1
Solution1
Upgrade react-native-webview per https://github.com/react-native-community/react-native-webview/issues/1011
Problem 2
This was coming from the
initializeFlipper
method inMainApplication.java
.Solution 2
Add this to
MainApplication.java
importsThis has been driving me crazy. I’ve lost track of the amount of things I’ve tried haha. A build setting in Xcode that got rid of these errors for me (giving way to entirely new errors instead… kill… me… ) was “Don’t Dead-Strip Inits and Terms”.
I also noticed that removing that second entry (
$(TOOLCHAIN_DIR)/usr/lib/swift-5.0/$(PLATFORM_NAME)
) makes the project build without making any other changes.I wonder if we really need that, because from the error message it sounds like it’s looking for
_swift_getFunctionReplacement50
instead of_swift_getFunctionReplacement
without 50 which I assume has to do with swift 5.What will happen if we just omit that second file (since the project get’s built)? Any ideas?
Facing the same issue but Strip Debug Symbols During Copy didn’t help 😦