mirror of
https://github.com/status-im/react-native.git
synced 2025-01-16 12:34:17 +00:00
90f9f48498
Summary: Currently the `react-native bundle` has no option to reset the file cache. For example changing the .babelrc has no effect on the bundling process. `react-native start` has it already implemented, so this is just a small addition. **Test plan (required)** the issue: - `react-native init` a new project - run `react-native bundle` (should work as expected) - create `.babelrc` with empty object ```{}``` - rerun `react-native bundle` - should fail now with `Unexptected token` (no babel plugins configured) - if not failing, your cache already hit (clear $TMPDIR to get the error) - delete .babelrc and rerun `bundle` - still failing, but it should went back to normal - delete your $TMPDIR contents - works again The option `--reset-cache` should fix that Closes https://github.com/facebook/react-native/pull/7297 Differential Revision: D3241259 Pulled By: davidaurelio fb-gh-sync-id: 0ed5b58aa1f021d72021f4c80fbc57d2e7e8181f fbshipit-source-id: 0ed5b58aa1f021d72021f4c80fbc57d2e7e8181f
79 lines
2.5 KiB
JavaScript
79 lines
2.5 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.
|
|
*/
|
|
|
|
const log = require('../util/log').out('bundle');
|
|
const outputBundle = require('./output/bundle');
|
|
const Promise = require('promise');
|
|
const saveAssets = require('./saveAssets');
|
|
const Server = require('../../packager/react-packager/src/Server');
|
|
|
|
function saveBundle(output, bundle, args) {
|
|
return Promise.resolve(
|
|
output.save(bundle, args, log)
|
|
).then(() => bundle);
|
|
}
|
|
|
|
function buildBundle(args, config, output = outputBundle, packagerInstance) {
|
|
return new Promise((resolve, reject) => {
|
|
|
|
// 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 options = {
|
|
projectRoots: config.getProjectRoots(),
|
|
assetRoots: config.getAssetRoots(),
|
|
blacklistRE: config.getBlacklistRE(args.platform),
|
|
getTransformOptionsModulePath: config.getTransformOptionsModulePath,
|
|
transformModulePath: args.transformer,
|
|
extraNodeModules: config.extraNodeModules,
|
|
nonPersistent: true,
|
|
resetCache: args['reset-cache'],
|
|
};
|
|
|
|
const requestOpts = {
|
|
entryFile: args['entry-file'],
|
|
sourceMapUrl: args['sourcemap-output'],
|
|
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) {
|
|
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['assets-dest']
|
|
));
|
|
|
|
// When we're done saving bundle output and the assets, we're done.
|
|
resolve(assets);
|
|
});
|
|
}
|
|
|
|
module.exports = buildBundle;
|