mirror of
https://github.com/status-im/react-native.git
synced 2025-01-09 17:15:54 +00:00
43f18ffd08
Summary: This adds a build option for using Prepack (an experimental packager) to build a bundle. It doesn't actually take on the npm package dependency because it's not published/open source (yet). This will be used while we experiment and should be maintained as the build system changes so that we can continue getting fresh builds. I found that saveBundleAndMap and processBundle were over abstracted and got in my way so I inlined it and removed the unit tests because the unit test was testing trivial code that is likely to change interface. I went with a separate build phase and a separate Bundle class even though there are a lot of commonalities. I imagine that the requirements for Prepack will continue to diverge. Especially for source maps but a larger refactor could try to unify these a bit more. The fact that modules are wrapped before the write phase seems to be an unfortunate architecture that makes this difficult. Closes https://github.com/facebook/react-native/pull/4226 Reviewed By: amasad Differential Revision: D2673760 Pulled By: sebmarkbage fb-gh-sync-id: 299ccc42e4be1d9dee19ade443ea3388db2e39a8
139 lines
3.6 KiB
JavaScript
139 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 fs = require('fs');
|
|
const log = require('../util/log').out('bundle');
|
|
const Promise = require('promise');
|
|
const ReactPackager = require('../../packager/react-packager');
|
|
const saveAssets = require('./saveAssets');
|
|
|
|
const sign = require('./sign');
|
|
|
|
function saveBundleAndMap(
|
|
bundle,
|
|
bundleOutput,
|
|
encoding,
|
|
sourcemapOutput,
|
|
dev
|
|
) {
|
|
log('start');
|
|
let codeWithMap;
|
|
if (!dev) {
|
|
codeWithMap = bundle.getMinifiedSourceAndMap(dev);
|
|
} else {
|
|
codeWithMap = {
|
|
code: bundle.getSource({ dev }),
|
|
map: JSON.stringify(bundle.getSourceMap({ dev })),
|
|
};
|
|
}
|
|
log('finish');
|
|
|
|
log('Writing bundle output to:', bundleOutput);
|
|
fs.writeFileSync(bundleOutput, sign(codeWithMap.code), encoding);
|
|
log('Done writing bundle output');
|
|
|
|
if (sourcemapOutput) {
|
|
log('Writing sourcemap output to:', sourcemapOutput);
|
|
fs.writeFileSync(sourcemapOutput, codeWithMap.map);
|
|
log('Done writing sourcemap output');
|
|
}
|
|
}
|
|
|
|
function savePrepackBundleAndMap(
|
|
bundle,
|
|
bundleOutput,
|
|
sourcemapOutput,
|
|
bridgeConfig
|
|
) {
|
|
log('Writing prepack bundle output to:', bundleOutput);
|
|
const result = bundle.build({
|
|
batchedBridgeConfig: bridgeConfig
|
|
});
|
|
fs.writeFileSync(bundleOutput, result, 'ucs-2');
|
|
log('Done writing prepack bundle output');
|
|
}
|
|
|
|
function buildBundle(args, config) {
|
|
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(),
|
|
transformModulePath: args.transformer,
|
|
verbose: args.verbose,
|
|
};
|
|
|
|
const requestOpts = {
|
|
entryFile: args['entry-file'],
|
|
dev: args.dev,
|
|
minify: !args.dev,
|
|
platform: args.platform,
|
|
};
|
|
|
|
const prepack = args.prepack;
|
|
|
|
const client = ReactPackager.createClientFor(options);
|
|
|
|
client.then(() => log('Created ReactPackager'));
|
|
|
|
// Build and save the bundle
|
|
let bundle;
|
|
if (prepack) {
|
|
bundle = client.then(c => c.buildPrepackBundle(requestOpts))
|
|
.then(outputBundle => {
|
|
savePrepackBundleAndMap(
|
|
outputBundle,
|
|
args['bundle-output'],
|
|
args['sourcemap-output'],
|
|
args['bridge-config']
|
|
);
|
|
return outputBundle;
|
|
});
|
|
} else {
|
|
bundle = client.then(c => c.buildBundle(requestOpts))
|
|
.then(outputBundle => {
|
|
saveBundleAndMap(
|
|
outputBundle,
|
|
args['bundle-output'],
|
|
args['bundle-encoding'],
|
|
args['sourcemap-output'],
|
|
args.dev
|
|
);
|
|
return outputBundle;
|
|
});
|
|
}
|
|
|
|
// When we're done bundling, close the client
|
|
bundle.then(() => client.then(c => {
|
|
log('Closing client');
|
|
c.close();
|
|
}));
|
|
|
|
// Save the assets of the bundle
|
|
const assets = bundle
|
|
.then(outputBundle => outputBundle.getAssets())
|
|
.then(outputAssets => saveAssets(
|
|
outputAssets,
|
|
args.platform,
|
|
args['assets-dest']
|
|
));
|
|
|
|
// When we're done saving the assets, we're done.
|
|
resolve(assets);
|
|
});
|
|
}
|
|
|
|
module.exports = buildBundle;
|