mirror of
https://github.com/status-im/react-native.git
synced 2025-01-24 16:29:01 +00:00
f0daaf3568
Summary: In this diff I change the internal react-native cli to use our new configuration. Another change here is that Metro starts using the new configuration already as its entry points (like `metro#runMetro`). Reviewed By: rafeca Differential Revision: D8728612 fbshipit-source-id: 9f43dee31ebaccd35cf6274d5c4dec0a227a6eec
124 lines
3.4 KiB
JavaScript
124 lines
3.4 KiB
JavaScript
/**
|
|
* Copyright (c) 2015-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
|
|
*/
|
|
|
|
'use strict';
|
|
|
|
const Metro = require('metro');
|
|
const {convert} = require('metro-config');
|
|
|
|
const denodeify = require('denodeify');
|
|
const fs = require('fs');
|
|
const path = require('path');
|
|
|
|
const {ASSET_REGISTRY_PATH} = require('../core/Constants');
|
|
|
|
async function dependencies(argv, configPromise, args, packagerInstance) {
|
|
const rootModuleAbsolutePath = args.entryFile;
|
|
const config = await configPromise;
|
|
if (!fs.existsSync(rootModuleAbsolutePath)) {
|
|
return Promise.reject(
|
|
new Error(`File ${rootModuleAbsolutePath} does not exist`),
|
|
);
|
|
}
|
|
|
|
config.cacheStores = [];
|
|
config.transformModulePath = args.transformer
|
|
? path.resolve(args.transformer)
|
|
: config.transformModulePath;
|
|
config.transformer.transformModulePath = ASSET_REGISTRY_PATH;
|
|
|
|
const {serverOptions: packageOpts} = convert.convertNewToOld(config);
|
|
|
|
const relativePath = path.relative(
|
|
packageOpts.projectRoot,
|
|
rootModuleAbsolutePath,
|
|
);
|
|
|
|
const options = {
|
|
platform: args.platform,
|
|
entryFile: relativePath,
|
|
dev: args.dev,
|
|
minify: false,
|
|
generateSourceMaps: !args.dev,
|
|
};
|
|
|
|
const writeToFile = args.output;
|
|
const outStream = writeToFile
|
|
? fs.createWriteStream(args.output)
|
|
: process.stdout;
|
|
|
|
return Promise.resolve(
|
|
(packagerInstance
|
|
? packagerInstance.getOrderedDependencyPaths(options)
|
|
: Metro.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.watchFolders.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',
|
|
description: 'lists 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,
|
|
},
|
|
],
|
|
};
|