Logo Questions Linux Laravel Mysql Ubuntu Git Menu
 

React native base headers for ios not found

During the iOS linking phase, I started seeing errors for my React Native project.

React Native version: 0.41.2, 0.40, 0.39

All worked fine, I edited the Android version, React Native code didn't change, when this kind of linking errors started showing up with headers on /node_modules/react-native/React/Base/{RCTHeaderName.h} path not being found:

The error

In file included from /Users/user/ReactNativeProject/node_modules/react-native-vector-icons/RNVectorIconsManager/RNVectorIconsManager.h:9:
../react-native/React/Base/RCTBridgeModule.h:12:9: fatal error: 'React/RCTDefines.h' file not found
#import <React/RCTDefines.h>
        ^
  • In the Link Binary With Libraries I include the core React library (libReact.a).

  • The location of the RCTLog.h is PROJECTROOT/node_modules/react-native/React/Base/RCTLog.h, but the import is #import <React/RCTLog.h>

  • Newly adding React.xcodeproj into Libraries doesn't help, Xcode's Product > Clean doesn't help, neither does restarting Xcode

  • react-native run-android works, react-native run-ios shows the error

  • File permissions set to the user executing react-native run-ios

like image 618
Peter G. Avatar asked Feb 10 '17 11:02

Peter G.


3 Answers

Do you have Parallelize build option unchecked and React listed first in your build targets?

You can find this window in Xcode => Your project icon near the run button => Edit scheme => Build tab

like image 82
binchik Avatar answered Oct 13 '22 19:10

binchik


Update: solution on Facebook React-Native https://github.com/facebook/react-native/issues/11813

============

This issue happened to me also. It seems React.xcodeproj only recognise configuration Debug and Release. All of output of React.xcodeproj is written into Debug-iphonesimulator or Release-iphonesimulator.

That means if you have some configurations other than "Debug/Release", the output will still be written into Debug-iphonesimulator or Release-iphonesimulator, that is not what we want.

So the solution is to add a same configuration in React.xcodeproj to match the one of your own project.

For example, if you have "Debug/Release/Test/AppStore" 4 configurations in your own project, you have to make sure React.xcodeproj also has the same 4 configurations.

please click the "+" button of Configurations, then "Duplicate Release Configuration", and rename it according to you need.

enter image description here

like image 40
DàChún Avatar answered Oct 13 '22 20:10

DàChún


It seems like there are a lot of reasons to be getting these 'missing headers' errors and I've tried a lot of things posted on Stack Overflow and nothing would work. Finally I stumbled upon the solution below that did work for me. Posting in case anyone else has the same issue ... its a bit obscure. For me it was caused by a build locations setting in Xcode that is apparently incompatible with vanilla React Native. The build locations setting that fixed this issue is shown here:

in XCode->Settings>Locations->Advanced... make sure your Build Location is not set to Legacy, it should be set to Unique

Note: the vanilla React Native application may have to be reinitialized from scratch with react-native init ... after changing this setting.

like image 25
Tom Lachapelle Avatar answered Oct 13 '22 20:10

Tom Lachapelle