mirror of
https://github.com/status-im/react-native.git
synced 2025-01-12 18:44:25 +00:00
03476a225e
Summary: This pull request adds the ability for a platform developer to provide a `"haste"` key under the `"rnpm"` key in their `package.json` which allows the packager to pick up that platform's javascript files. The intent is to remove the need to have custom platforms hardcoded in. This is inspired by the `"jest": { "haste": {} }` key used by jest. For example, React Native Dom would have an entry like: ```json { "rnpm": { "haste": { "providesModuleNodeModules": [ "react-native-dom" ], "platforms": [ "dom" ] } } } ``` Support for more keys (path blacklists perhaps?) could be added in the future. This succeeds #20662, as per a discussion I had with matthargett. I've got an open discussion over here as well: https://github.com/react-native-community/discussions-and-proposals/issues/21 Pull Request resolved: https://github.com/facebook/react-native/pull/20825 Differential Revision: D9596429 Pulled By: hramos fbshipit-source-id: a02f0da0bea8870bdc45d55e23da8ccbc36249f2
98 lines
2.4 KiB
JavaScript
98 lines
2.4 KiB
JavaScript
/**
|
|
* Copyright (c) 2014-present, Facebook, Inc.
|
|
*
|
|
* This source code is licensed under the MIT license found in the
|
|
* LICENSE file in the root directory of this source tree.
|
|
*
|
|
* @format
|
|
* @flow
|
|
*/
|
|
|
|
'use strict';
|
|
|
|
const path = require('path');
|
|
const findPlugins = require('../local-cli/core/findPlugins');
|
|
|
|
const plugins = findPlugins([path.resolve(__dirname, '../../../')]);
|
|
|
|
// Detect out-of-tree platforms and add them to the whitelists
|
|
const pluginRoots /*: Array<
|
|
string,
|
|
> */ = plugins.haste.providesModuleNodeModules.map(
|
|
name => path.resolve(__dirname, '../../', name) + path.sep,
|
|
);
|
|
|
|
const pluginNameReducers /*: Array<
|
|
[RegExp, string],
|
|
> */ = plugins.haste.platforms.map(name => [
|
|
new RegExp(`^(.*)\.(${name})$`),
|
|
'$1',
|
|
]);
|
|
|
|
const ROOTS = [path.resolve(__dirname, '..') + path.sep, ...pluginRoots];
|
|
|
|
const BLACKLISTED_PATTERNS /*: Array<RegExp> */ = [
|
|
/.*[\\\/]__(mocks|tests)__[\\\/].*/,
|
|
/^Libraries[\\\/]Animated[\\\/]src[\\\/]polyfills[\\\/].*/,
|
|
/^Libraries[\\\/]Renderer[\\\/]fb[\\\/].*/,
|
|
];
|
|
|
|
const WHITELISTED_PREFIXES /*: Array<string> */ = [
|
|
'IntegrationTests',
|
|
'Libraries',
|
|
'ReactAndroid',
|
|
'RNTester',
|
|
];
|
|
|
|
const NAME_REDUCERS /*: Array<[RegExp, string]> */ = [
|
|
// extract basename
|
|
[/^(?:.*[\\\/])?([a-zA-Z0-9$_.-]+)$/, '$1'],
|
|
// strip .js/.js.flow suffix
|
|
[/^(.*)\.js(\.flow)?$/, '$1'],
|
|
// strip platform suffix
|
|
[/^(.*)\.(android|ios|native)$/, '$1'],
|
|
// strip plugin platform suffixes
|
|
...pluginNameReducers,
|
|
];
|
|
|
|
const haste = {
|
|
/*
|
|
* @return {string|void} hasteName for module at filePath; or undefined if
|
|
* filePath is not a haste module
|
|
*/
|
|
getHasteName(
|
|
filePath /*: string */,
|
|
sourceCode /*: ?string */,
|
|
) /*: string | void */ {
|
|
if (!isHastePath(filePath)) {
|
|
return undefined;
|
|
}
|
|
|
|
const hasteName = NAME_REDUCERS.reduce(
|
|
(name, [pattern, replacement]) => name.replace(pattern, replacement),
|
|
filePath,
|
|
);
|
|
|
|
return hasteName;
|
|
},
|
|
};
|
|
|
|
function isHastePath(filePath /*: string */) /*: boolean */ {
|
|
if (!filePath.endsWith('.js') && !filePath.endsWith('.js.flow')) {
|
|
return false;
|
|
}
|
|
|
|
const root = ROOTS.find(r => filePath.startsWith(r));
|
|
if (!root) {
|
|
return false;
|
|
}
|
|
|
|
filePath = filePath.substr(root.length);
|
|
if (BLACKLISTED_PATTERNS.some(pattern => pattern.test(filePath))) {
|
|
return false;
|
|
}
|
|
return WHITELISTED_PREFIXES.some(prefix => filePath.startsWith(prefix));
|
|
}
|
|
|
|
module.exports = haste;
|