mirror of
https://github.com/status-im/react-native.git
synced 2025-01-19 14:02:10 +00:00
8edc35004c
Summary:We found that moving the preloaded modules to the startup section of the RAM Bundle improves TTI quite a bit by saving lots of through the bridge calls and injecting multiple modules at once on JSC. However, doing this on a non hacky way required a lot of work. The main changes this diff does are: - Add to `BundleBase` additional bundling options. This options are fetched based on the entry file we're building by invoking a module that exports a function (`getBundleOptionsModulePath`). - Implement `BundleOptions` module to include the `numPreloadedModules` attribute as a bundle additional option. This value is computed by getting the dependencies the entry file has and looking for the first module that exports a module we don't want to preload. The `numPreloadedModules` attribute is then used to decide where to splice the array of modules. - Additional kung fu to make sure sourcemaps work for both preloaded and non preloaded modules. Reviewed By: davidaurelio Differential Revision: D3046534 fb-gh-sync-id: 80b676222ca3bb8b9eecc912a7963be94d3dee1a shipit-source-id: 80b676222ca3bb8b9eecc912a7963be94d3dee1a
85 lines
2.7 KiB
JavaScript
85 lines
2.7 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 mkdirp = require('mkdirp');
|
|
const path = require('path');
|
|
const Promise = require('promise');
|
|
|
|
const buildSourceMapWithMetaData = require('./build-unbundle-sourcemap-with-metadata');
|
|
const writeFile = require('../writeFile');
|
|
const writeSourceMap = require('./write-sourcemap');
|
|
const MAGIC_UNBUNDLE_NUMBER = require('./magic-number');
|
|
const MAGIC_UNBUNDLE_FILENAME = 'UNBUNDLE'; // must not start with a dot, as that won't go into the apk
|
|
const MODULES_DIR = 'js-modules';
|
|
|
|
/**
|
|
* Saves all JS modules of an app as single files
|
|
* The startup code (prelude, polyfills etc.) are written to the file
|
|
* designated by the `bundleOuput` option.
|
|
* All other modules go into a 'js-modules' folder that in the same parent
|
|
* directory as the startup file.
|
|
*/
|
|
function saveAsAssets(bundle, options, log) {
|
|
const {
|
|
'bundle-output': bundleOutput,
|
|
'bundle-encoding': encoding,
|
|
'sourcemap-output': sourcemapOutput,
|
|
} = options;
|
|
|
|
log('start');
|
|
const {startupCode, startupModules, modules} = bundle.getUnbundle('ASSETS');
|
|
log('finish');
|
|
|
|
log('Writing bundle output to:', bundleOutput);
|
|
const modulesDir = path.join(path.dirname(bundleOutput), MODULES_DIR);
|
|
const writeUnbundle =
|
|
createDir(modulesDir).then( // create the modules directory first
|
|
Promise.all([
|
|
writeModules(modules, modulesDir, encoding),
|
|
writeFile(bundleOutput, startupCode, encoding),
|
|
writeMagicFlagFile(modulesDir),
|
|
])
|
|
);
|
|
writeUnbundle.then(() => log('Done writing unbundle output'));
|
|
|
|
const sourceMap =
|
|
buildSourceMapWithMetaData({startupModules, modules});
|
|
|
|
return Promise.all([
|
|
writeUnbundle,
|
|
writeSourceMap(sourcemapOutput, JSON.stringify(sourceMap), log)
|
|
]);
|
|
}
|
|
|
|
function createDir(dirName) {
|
|
return new Promise((resolve, reject) =>
|
|
mkdirp(dirName, error => error ? reject(error) : resolve()));
|
|
}
|
|
|
|
function writeModuleFile(module, modulesDir, encoding) {
|
|
const {code, id} = module;
|
|
return writeFile(path.join(modulesDir, id + '.js'), code, encoding);
|
|
}
|
|
|
|
function writeModules(modules, modulesDir, encoding) {
|
|
const writeFiles =
|
|
modules.map(module => writeModuleFile(module, modulesDir, encoding));
|
|
return Promise.all(writeFiles);
|
|
}
|
|
|
|
function writeMagicFlagFile(outputDir) {
|
|
/* global Buffer: true */
|
|
const buffer = Buffer(4);
|
|
buffer.writeUInt32LE(MAGIC_UNBUNDLE_NUMBER);
|
|
return writeFile(path.join(outputDir, MAGIC_UNBUNDLE_FILENAME), buffer);
|
|
}
|
|
|
|
module.exports = saveAsAssets;
|