mirror of
https://github.com/status-im/react-native.git
synced 2025-01-16 20:44:10 +00:00
30e89b49f1
Summary: This is step one on merging the `rnpm` config with the `cli config`. The plan is to remove two sources of truth (rnpm package.json config and rn-cli Javascript config) Rationale: As of now, we have `rnpm` config, that used to live in the `local-cli/core/config/index.js` and the `rn-cli` config, living in `default.config.js` and `utils/Config.js`. This PR moves all the things into one file, called `local-cli/core', simplifies things, enhances types (Config now has better types, added missing properties and fixed descriptions). One notable addition is that users can now opt-in to override the commands that are loaded at the package level. Previously it was only possible to add a command by writing a plugin. Now, you can just tweak the `rn-cli.config.js`. This is one of the several improvements I have on my roadmap, with better documentation for the CLI as well. Closes https://github.com/facebook/react-native/pull/11564 Differential Revision: D4360095 fbshipit-source-id: feaec7c88df63e51cef1f9620c7eedeb738d3d00
104 lines
3.1 KiB
JavaScript
104 lines
3.1 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 log = require('../util/log').out('bundle');
|
|
const Server = require('../../packager/react-packager/src/Server');
|
|
const TerminalReporter = require('../../packager/react-packager/src/lib/TerminalReporter');
|
|
|
|
const outputBundle = require('./output/bundle');
|
|
const path = require('path');
|
|
const saveAssets = require('./saveAssets');
|
|
const defaultAssetExts = require('../../packager/defaults').assetExts;
|
|
|
|
import type {RequestOptions, OutputOptions} from './types.flow';
|
|
import type {ConfigT} from '../core';
|
|
|
|
function saveBundle(output, bundle, args) {
|
|
return Promise.resolve(
|
|
output.save(bundle, args, log)
|
|
).then(() => bundle);
|
|
}
|
|
|
|
function buildBundle(
|
|
args: OutputOptions & {
|
|
assetsDest: mixed,
|
|
entryFile: string,
|
|
resetCache: boolean,
|
|
transformer: string,
|
|
},
|
|
config: ConfigT,
|
|
output = outputBundle,
|
|
packagerInstance,
|
|
) {
|
|
// This is used by a bazillion of npm modules we don't control so we don't
|
|
// have other choice than defining it as an env variable here.
|
|
process.env.NODE_ENV = args.dev ? 'development' : 'production';
|
|
|
|
const requestOpts: RequestOptions = {
|
|
entryFile: args.entryFile,
|
|
sourceMapUrl: args.sourcemapOutput && path.basename(args.sourcemapOutput),
|
|
dev: args.dev,
|
|
minify: !args.dev,
|
|
platform: args.platform,
|
|
};
|
|
|
|
// If a packager instance was not provided, then just create one for this
|
|
// bundle command and close it down afterwards.
|
|
var shouldClosePackager = false;
|
|
if (!packagerInstance) {
|
|
const assetExts = (config.getAssetExts && config.getAssetExts()) || [];
|
|
|
|
const transformModulePath =
|
|
args.transformer ? path.resolve(args.transformer) :
|
|
typeof config.getTransformModulePath === 'function' ? config.getTransformModulePath() :
|
|
undefined;
|
|
|
|
const options = {
|
|
projectRoots: config.getProjectRoots(),
|
|
assetExts: defaultAssetExts.concat(assetExts),
|
|
blacklistRE: config.getBlacklistRE(),
|
|
getTransformOptions: config.getTransformOptions,
|
|
transformModulePath: transformModulePath,
|
|
extraNodeModules: config.extraNodeModules,
|
|
resetCache: args.resetCache,
|
|
watch: false,
|
|
reporter: new TerminalReporter(),
|
|
};
|
|
|
|
packagerInstance = new Server(options);
|
|
shouldClosePackager = true;
|
|
}
|
|
|
|
const bundlePromise = output.build(packagerInstance, requestOpts)
|
|
.then(bundle => {
|
|
if (shouldClosePackager) {
|
|
packagerInstance.end();
|
|
}
|
|
return saveBundle(output, bundle, args);
|
|
});
|
|
|
|
// Save the assets of the bundle
|
|
const assets = bundlePromise
|
|
.then(bundle => bundle.getAssets())
|
|
.then(outputAssets => saveAssets(
|
|
outputAssets,
|
|
args.platform,
|
|
args.assetsDest,
|
|
));
|
|
|
|
// When we're done saving bundle output and the assets, we're done.
|
|
return assets;
|
|
}
|
|
|
|
module.exports = buildBundle;
|