mirror of
https://github.com/status-im/react-native.git
synced 2025-01-10 01:25:39 +00:00
4978855d72
Summary: In javascriptcore(ios9), this code will run as expected(output 0 1): ```js for(let i=0; i<2; i++) { const data = i; console.log(data); } ``` But when debug in chrome, the above code will fail without `use strict` prologue (if you add prologue, rn will fail with red screen `Const declarations are not supported in strict mode`): https://code.google.com/p/v8/issues/detail?id=4432. So it's better to transpile contant by default. Closes https://github.com/facebook/react-native/pull/2955 Reviewed By: @svcscm Differential Revision: D2483398 Pulled By: @vjeux
78 lines
1.8 KiB
JavaScript
78 lines
1.8 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.
|
|
*
|
|
* Note: This is a fork of the fb-specific transform.js
|
|
*/
|
|
'use strict';
|
|
|
|
const babel = require('babel-core');
|
|
const inlineRequires = require('fbjs-scripts/babel/inline-requires');
|
|
|
|
function transform(src, filename, options) {
|
|
const plugins = [];
|
|
|
|
if (process.env.NODE_ENV === 'production') {
|
|
plugins.push('node-env-inline', 'dunderscore-dev-inline');
|
|
} else if (process.env.NODE_ENV === 'test') {
|
|
plugins.push({
|
|
position: 'after',
|
|
transformer: inlineRequires,
|
|
});
|
|
}
|
|
|
|
const result = babel.transform(src, {
|
|
retainLines: true,
|
|
compact: true,
|
|
comments: false,
|
|
filename,
|
|
whitelist: [
|
|
// Keep in sync with packager/react-packager/.babelrc
|
|
'es6.arrowFunctions',
|
|
'es6.blockScoping',
|
|
'es6.classes',
|
|
'es6.constants',
|
|
'es6.destructuring',
|
|
'es6.parameters',
|
|
'es6.properties.computed',
|
|
'es6.properties.shorthand',
|
|
'es6.spread',
|
|
'es6.templateLiterals',
|
|
'es7.asyncFunctions',
|
|
'es7.trailingFunctionCommas',
|
|
'es7.objectRestSpread',
|
|
'flow',
|
|
'react',
|
|
'react.displayName',
|
|
'regenerator',
|
|
],
|
|
plugins,
|
|
sourceFileName: filename,
|
|
sourceMaps: false,
|
|
extra: options || {},
|
|
});
|
|
|
|
return {
|
|
code: result.code
|
|
};
|
|
}
|
|
|
|
module.exports = function(data, callback) {
|
|
let result;
|
|
try {
|
|
result = transform(data.sourceCode, data.filename);
|
|
} catch (e) {
|
|
callback(e);
|
|
return;
|
|
}
|
|
|
|
callback(null, result);
|
|
};
|
|
|
|
// export for use in jest
|
|
module.exports.transform = transform;
|