mirror of
https://github.com/status-im/metro.git
synced 2025-01-17 22:50:55 +00:00
Move HMR to internal transform
Summary: public We want to support Hot Loading on the packager itself instead of on the transformer. This will allow us to enable it on OSS (and for any scripting language, yay!). For now to enable Hot Loading the packager's internals transforms need to be manually enabled (start packager with `--enable-internal-transforms`). I think the internal pipeline should always be enabled as it doesn't affect performance if there're no transforms and the user can disable Hot Loading through the setting on the app though. I'll tweak this on a follow up commit. Reviewed By: vjeux Differential Revision: D2801343 fb-gh-sync-id: 563984d77b10c3925fda6fd5616b814cdbea2c66
This commit is contained in:
parent
e02756ca21
commit
9e5dfbddbc
5
react-packager/src/Bundler/index.js
vendored
5
react-packager/src/Bundler/index.js
vendored
@ -56,10 +56,6 @@ const validateOpts = declareOpts({
|
||||
type:'string',
|
||||
required: false,
|
||||
},
|
||||
enableInternalTransforms: {
|
||||
type: 'boolean',
|
||||
default: false,
|
||||
},
|
||||
nonPersistent: {
|
||||
type: 'boolean',
|
||||
default: false,
|
||||
@ -135,7 +131,6 @@ class Bundler {
|
||||
blacklistRE: opts.blacklistRE,
|
||||
cache: this._cache,
|
||||
transformModulePath: opts.transformModulePath,
|
||||
enableInternalTransforms: opts.enableInternalTransforms,
|
||||
});
|
||||
|
||||
this._projectRoots = opts.projectRoots;
|
||||
|
6
react-packager/src/JSTransformer/index.js
vendored
6
react-packager/src/JSTransformer/index.js
vendored
@ -53,10 +53,6 @@ const validateOpts = declareOpts({
|
||||
type: 'number',
|
||||
default: DEFAULT_MAX_CALL_TIME,
|
||||
},
|
||||
enableInternalTransforms: {
|
||||
type: 'boolean',
|
||||
default: false,
|
||||
},
|
||||
});
|
||||
|
||||
class Transformer {
|
||||
@ -65,7 +61,6 @@ class Transformer {
|
||||
|
||||
this._cache = opts.cache;
|
||||
this._transformModulePath = opts.transformModulePath;
|
||||
this._enableInternalTransforms = opts.enableInternalTransforms;
|
||||
|
||||
if (opts.transformModulePath != null) {
|
||||
this._workers = workerFarm({
|
||||
@ -111,7 +106,6 @@ class Transformer {
|
||||
options: {
|
||||
...options,
|
||||
externalTransformModulePath: this._transformModulePath,
|
||||
enableInternalTransforms: this._enableInternalTransforms,
|
||||
},
|
||||
}).then(res => {
|
||||
if (res.error) {
|
||||
|
17
react-packager/src/JSTransformer/worker.js
vendored
17
react-packager/src/JSTransformer/worker.js
vendored
@ -22,7 +22,7 @@ function internalTransforms(sourceCode, filename, options) {
|
||||
filename: filename,
|
||||
sourceFileName: filename,
|
||||
sourceMaps: false,
|
||||
plugins: Transforms.getAll()
|
||||
plugins: Transforms.getAll(options)
|
||||
});
|
||||
|
||||
return {
|
||||
@ -37,16 +37,11 @@ function onExternalTransformDone(data, callback, error, externalOutput) {
|
||||
return;
|
||||
}
|
||||
|
||||
var result;
|
||||
if (data.options.enableInternalTransforms) {
|
||||
result = internalTransforms(
|
||||
externalOutput.code,
|
||||
externalOutput.filename,
|
||||
data.options
|
||||
);
|
||||
} else {
|
||||
result = externalOutput;
|
||||
}
|
||||
var result = internalTransforms(
|
||||
externalOutput.code,
|
||||
externalOutput.filename,
|
||||
data.options
|
||||
);
|
||||
|
||||
callback(null, result);
|
||||
}
|
||||
|
4
react-packager/src/Server/index.js
vendored
4
react-packager/src/Server/index.js
vendored
@ -52,10 +52,6 @@ const validateOpts = declareOpts({
|
||||
type: 'boolean',
|
||||
default: false,
|
||||
},
|
||||
enableInternalTransforms: {
|
||||
type: 'boolean',
|
||||
default: false,
|
||||
},
|
||||
assetRoots: {
|
||||
type: 'array',
|
||||
required: false,
|
||||
|
25
react-packager/src/transforms/index.js
vendored
25
react-packager/src/transforms/index.js
vendored
@ -8,9 +8,26 @@
|
||||
*/
|
||||
'use strict';
|
||||
|
||||
exports.getAll = function() {
|
||||
return [
|
||||
require('./babel-plugin-system-import'),
|
||||
];
|
||||
exports.getAll = function(options) {
|
||||
var plugins = [];
|
||||
if (options.hot) {
|
||||
plugins = plugins.concat([
|
||||
[
|
||||
'react-transform',
|
||||
{
|
||||
transforms: [{
|
||||
transform: 'react-transform-hmr/lib/index.js',
|
||||
imports: ['React'],
|
||||
locals: ['module'],
|
||||
}]
|
||||
},
|
||||
],
|
||||
'transform-es2015-block-scoping',
|
||||
'transform-es2015-constants',
|
||||
['transform-es2015-modules-commonjs', {strict: false, allowTopLevelThis: true}],
|
||||
]);
|
||||
}
|
||||
|
||||
return plugins;
|
||||
};
|
||||
|
||||
|
@ -54,8 +54,6 @@ function transform(src, filename, options) {
|
||||
return plugin;
|
||||
});
|
||||
|
||||
config.plugins = config.plugins.concat(ReactPackager.getTransforms());
|
||||
|
||||
const result = babel.transform(src, Object.assign({}, babelRC, config));
|
||||
|
||||
return {
|
||||
|
Loading…
x
Reference in New Issue
Block a user