mirror of
https://github.com/status-im/react-native.git
synced 2025-01-14 11:34:23 +00:00
29d9c35e12
Summary: This diff cleans up some cruft and adds some features: * It removes the usage of an env variable to control workers. * It removes the lazy and handwavy calculation on how many workers to use for jest-haste-map. Jest itself uses the maximum amount of workers available and it has never been reported as an issue – especially since it is a one-time startup cost of about 3 seconds on a cold cache only. * It adds a `--max-workers` flag to replace the env variable. This one is able to control both the number of workers for `jest-haste-map` as well as the transformers. * It makes the transformers run in the parent process if 1 or fewer workers are are specified. This should help with debugging. Once you approve this diff, I will publish a new version of metro to npm and update the version used in RN and remove the use of the env variable altogether: https://our.intern.facebook.com/intern/biggrep/?corpus=xplat&filename=&case=false&view=default&extre=&s=REACT_NATIVE_MAX_WORKERS&engine=apr_strmatch&context=false&filter[uninteresting]=false&filter[intern]=false&filter[test]=false&grep_regex= Note: the process of adding a CLI option is really broken. Commander also has a weird API. We should consider building a better public API for Metro and then consider how to build a new CLI on top of it and simplify our internal integration. I really don't like how Metro is integrated across pieces of the RN cli in ways that is hard to manage. But that is a larger task for another time :) Reviewed By: jeanlauliac Differential Revision: D5217726 fbshipit-source-id: 74efddbb87755a9e744c816fbc62efa21f6a79bf
117 lines
3.6 KiB
JavaScript
117 lines
3.6 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.
|
|
*/
|
|
'use strict';
|
|
|
|
const ReactPackager = require('metro-bundler');
|
|
|
|
const denodeify = require('denodeify');
|
|
const fs = require('fs');
|
|
const path = require('path');
|
|
|
|
function dependencies(argv, config, args, packagerInstance) {
|
|
const rootModuleAbsolutePath = args.entryFile;
|
|
if (!fs.existsSync(rootModuleAbsolutePath)) {
|
|
return Promise.reject(`File ${rootModuleAbsolutePath} does not exist`);
|
|
}
|
|
|
|
const transformModulePath =
|
|
args.transformer ? path.resolve(args.transformer) :
|
|
typeof config.getTransformModulePath === 'function' ? config.getTransformModulePath() :
|
|
undefined;
|
|
|
|
const packageOpts = {
|
|
projectRoots: config.getProjectRoots(),
|
|
blacklistRE: config.getBlacklistRE(),
|
|
getTransformOptions: config.getTransformOptions,
|
|
hasteImpl: config.hasteImpl,
|
|
transformModulePath: transformModulePath,
|
|
extraNodeModules: config.extraNodeModules,
|
|
verbose: config.verbose,
|
|
workerPath: config.getWorkerPath(),
|
|
};
|
|
|
|
const relativePath = packageOpts.projectRoots.map(root =>
|
|
path.relative(
|
|
root,
|
|
rootModuleAbsolutePath
|
|
)
|
|
)[0];
|
|
|
|
const options = {
|
|
platform: args.platform,
|
|
entryFile: relativePath,
|
|
dev: args.dev,
|
|
minify: !args.dev,
|
|
generateSourceMaps: !args.dev,
|
|
};
|
|
|
|
const writeToFile = args.output;
|
|
const outStream = writeToFile
|
|
? fs.createWriteStream(args.output)
|
|
: process.stdout;
|
|
|
|
return Promise.resolve((packagerInstance ?
|
|
packagerInstance.getOrderedDependencyPaths(options) :
|
|
ReactPackager.getOrderedDependencyPaths(packageOpts, options)).then(
|
|
deps => {
|
|
deps.forEach(modulePath => {
|
|
// Temporary hack to disable listing dependencies not under this directory.
|
|
// Long term, we need either
|
|
// (a) JS code to not depend on anything outside this directory, or
|
|
// (b) Come up with a way to declare this dependency in Buck.
|
|
const isInsideProjectRoots = packageOpts.projectRoots.filter(
|
|
root => modulePath.startsWith(root)
|
|
).length > 0;
|
|
|
|
if (isInsideProjectRoots) {
|
|
outStream.write(modulePath + '\n');
|
|
}
|
|
});
|
|
return writeToFile
|
|
? denodeify(outStream.end).bind(outStream)()
|
|
: Promise.resolve();
|
|
}
|
|
));
|
|
}
|
|
|
|
module.exports = {
|
|
name: 'dependencies',
|
|
func: dependencies,
|
|
options: [
|
|
{
|
|
command: '--entry-file <path>',
|
|
description: 'Absolute path to the root JS file',
|
|
}, {
|
|
command: '--output [path]',
|
|
description: 'File name where to store the output, ex. /tmp/dependencies.txt',
|
|
}, {
|
|
command: '--platform [extension]',
|
|
description: 'The platform extension used for selecting modules',
|
|
}, {
|
|
command: '--transformer [path]',
|
|
description: 'Specify a custom transformer to be used'
|
|
}, {
|
|
command: '--max-workers [number]',
|
|
description: 'Specifies the maximum number of workers the worker-pool ' +
|
|
'will spawn for transforming files. This defaults to the number of the ' +
|
|
'cores available on your machine.',
|
|
parse: (workers: string) => Number(workers),
|
|
}, {
|
|
command: '--dev [boolean]',
|
|
description: 'If false, skip all dev-only code path',
|
|
parse: (val) => val === 'false' ? false : true,
|
|
default: true,
|
|
}, {
|
|
command: '--verbose',
|
|
description: 'Enables logging',
|
|
default: false,
|
|
},
|
|
],
|
|
};
|