mirror of
https://github.com/status-im/react-native.git
synced 2025-01-22 23:41:49 +00:00
8ad2ab3b5e
Summary: Instead of exposing a `getTransformOptionsModulePath` function in configurations, we can simply expose a `getTransformOptions` *function*. The necessity of exposing a path comes from the olden days, where we had a server listening on a socket, and a client, talking to that server. Since that architectural gem no longer exists, we can use functions directly, rather than passing paths to modules around. Reviewed By: cpojer Differential Revision: D4233551 fbshipit-source-id: ec1acef8e6495a2f1fd0911a5613c144e8ffd7c3
102 lines
3.0 KiB
JavaScript
102 lines
3.0 KiB
JavaScript
/**
|
|
* Copyright (c) 2015-present, Facebook, Inc.
|
|
* All rights reserved.
|
|
*
|
|
* This source code is licensed under the BSD-style license found in the
|
|
* LICENSE file in the root directory of this source tree. An additional grant
|
|
* of patent rights can be found in the PATENTS file in the same directory.
|
|
*
|
|
* @flow
|
|
*/
|
|
'use strict';
|
|
|
|
const assert = require('assert');
|
|
const fs = require('fs');
|
|
const path = require('path');
|
|
|
|
import type {GetTransformOptions} from '../../packager/react-packager/src/Bundler/index.js';
|
|
|
|
const RN_CLI_CONFIG = 'rn-cli.config.js';
|
|
|
|
export type ConfigT = {
|
|
extraNodeModules?: {[id: string]: string},
|
|
getAssetExts?: () => Array<string>,
|
|
getTransformModulePath?: () => string,
|
|
getTransformOptions?: GetTransformOptions<*>,
|
|
transformVariants?: () => {[name: string]: Object},
|
|
|
|
getBlacklistRE(): RegExp,
|
|
getProjectRoots(): Array<string>,
|
|
};
|
|
|
|
/**
|
|
* Module capable of getting the configuration that should be used for
|
|
* the `rn-cli`. The configuration file is a JS file named `rn-cli.config.js`.
|
|
* It has to be on any parent directory of the cli.
|
|
*
|
|
* The function will return all the default configuration functions overriden
|
|
* by those found on `rn-cli.config.js`, if any. If no default config is
|
|
* provided and no configuration can be found in the directory hierarchy an
|
|
* error will be thrown.
|
|
*/
|
|
const Config = {
|
|
get(
|
|
cwd: string,
|
|
defaultConfig?: ConfigT | null,
|
|
pathToConfig?: string | null,
|
|
): ConfigT {
|
|
let baseConfig;
|
|
|
|
// Handle the legacy code path where pathToConfig is unspecified
|
|
if (pathToConfig === undefined) {
|
|
const configPath = Config.findConfigPath(cwd);
|
|
if (!configPath && !defaultConfig) {
|
|
throw new Error(
|
|
`Can't find "${RN_CLI_CONFIG}" file in any parent folder of "${cwd}"`
|
|
);
|
|
}
|
|
// $FlowFixMe nope
|
|
baseConfig = require(configPath);
|
|
} else if (pathToConfig == null) {
|
|
assert(defaultConfig, 'Must have a default config if config is missing');
|
|
} else {
|
|
baseConfig = path.isAbsolute(pathToConfig) ?
|
|
// $FlowFixMe nope
|
|
require(pathToConfig) :
|
|
// $FlowFixMe nope
|
|
require(path.join(cwd, pathToConfig));
|
|
}
|
|
|
|
return {
|
|
...defaultConfig,
|
|
...baseConfig,
|
|
cwd,
|
|
};
|
|
},
|
|
|
|
findConfigPath(cwd: string): ?string {
|
|
const parentDir = findParentDirectory(cwd, RN_CLI_CONFIG);
|
|
return parentDir ? path.join(parentDir, RN_CLI_CONFIG) : null;
|
|
},
|
|
};
|
|
|
|
// Finds the most near ancestor starting at `currentFullPath` that has
|
|
// a file named `filename`
|
|
function findParentDirectory(currentFullPath, filename) {
|
|
const root = path.parse(currentFullPath).root;
|
|
const testDir = (parts) => {
|
|
if (parts.length === 0) {
|
|
return null;
|
|
}
|
|
|
|
const fullPath = path.join(root, parts.join(path.sep));
|
|
|
|
var exists = fs.existsSync(path.join(fullPath, filename));
|
|
return exists ? fullPath : testDir(parts.slice(0, -1));
|
|
};
|
|
|
|
return testDir(currentFullPath.substring(root.length).split(path.sep));
|
|
}
|
|
|
|
module.exports = Config;
|