2016-05-20 11:52:08 +00:00
|
|
|
/**
|
|
|
|
* Given Xcode project and path, iterate over all build configurations
|
|
|
|
* and execute func with HEADER_SEARCH_PATHS from current section
|
|
|
|
*
|
|
|
|
* We cannot use builtin addToHeaderSearchPaths method since react-native init does not
|
|
|
|
* use $(TARGET_NAME) for PRODUCT_NAME, but sets it manually so that method will skip
|
|
|
|
* that target.
|
|
|
|
*
|
|
|
|
* To workaround that issue and make it more bullet-proof for different names,
|
2017-01-12 22:56:55 +00:00
|
|
|
* we iterate over all configurations and look for `lc++` linker flag to detect
|
|
|
|
* React Native target.
|
2016-05-20 11:52:08 +00:00
|
|
|
*
|
|
|
|
* Important: That function mutates `buildSettings` and it's not pure thus you should
|
|
|
|
* not rely on its return value
|
|
|
|
*/
|
2017-01-12 22:56:55 +00:00
|
|
|
const defaultHeaderPaths = ['"$(inherited)"'];
|
|
|
|
|
2016-05-20 11:52:08 +00:00
|
|
|
module.exports = function headerSearchPathIter(project, func) {
|
|
|
|
const config = project.pbxXCBuildConfigurationSection();
|
|
|
|
|
|
|
|
Object
|
|
|
|
.keys(config)
|
|
|
|
.filter(ref => ref.indexOf('_comment') === -1)
|
|
|
|
.forEach(ref => {
|
|
|
|
const buildSettings = config[ref].buildSettings;
|
|
|
|
const shouldVisitBuildSettings = (
|
2017-01-12 22:56:55 +00:00
|
|
|
Array.isArray(buildSettings.OTHER_LDFLAGS) ?
|
|
|
|
buildSettings.OTHER_LDFLAGS :
|
2016-05-20 11:52:08 +00:00
|
|
|
[]
|
|
|
|
)
|
2017-01-12 22:56:55 +00:00
|
|
|
.indexOf('"-lc++"') >= 0;
|
2016-05-20 11:52:08 +00:00
|
|
|
|
|
|
|
if (shouldVisitBuildSettings) {
|
2017-01-12 22:56:55 +00:00
|
|
|
buildSettings.HEADER_SEARCH_PATHS = func(
|
|
|
|
buildSettings.HEADER_SEARCH_PATHS || defaultHeaderPaths
|
|
|
|
);
|
2016-05-20 11:52:08 +00:00
|
|
|
}
|
|
|
|
});
|
|
|
|
};
|