mirror of
https://github.com/status-im/react-native.git
synced 2025-01-16 20:44:10 +00:00
Remove the need for allowTopLevelThis in transform-es2015-modules-commonjs
Summary: This make the transform behave closer to the standard for modules. This removes the few places that a top level this was used to refer to the global space. It also clean up the usage of `GLOBAL` to use `global` instead as this is what is used everywhere else in the code base. We still define `GLOBAL` for compatibility with other modules. **Test plan** Clear the packager cache to make sure the transforms run again. (node ./local-cli/cli.js start --reset-cache). Run the Movies example (UIExplorer is broken atm) and make sure there are no errors. Closes https://github.com/facebook/react-native/pull/6255 Differential Revision: D3037227 Pulled By: mkonicek fb-gh-sync-id: bcf1350ae7a6e92c77d3a87fc9d6e42eb93cb9b9 fbshipit-source-id: bcf1350ae7a6e92c77d3a87fc9d6e42eb93cb9b9
This commit is contained in:
parent
373537b281
commit
169cfb5a52
@ -25,11 +25,11 @@
|
|||||||
require('regenerator/runtime');
|
require('regenerator/runtime');
|
||||||
|
|
||||||
if (typeof GLOBAL === 'undefined') {
|
if (typeof GLOBAL === 'undefined') {
|
||||||
global.GLOBAL = this;
|
global.GLOBAL = global;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (typeof window === 'undefined') {
|
if (typeof window === 'undefined') {
|
||||||
global.window = GLOBAL;
|
global.window = global;
|
||||||
}
|
}
|
||||||
|
|
||||||
function setUpConsole() {
|
function setUpConsole() {
|
||||||
@ -53,7 +53,7 @@ function setUpConsole() {
|
|||||||
* For more info on that particular case, see:
|
* For more info on that particular case, see:
|
||||||
* https://github.com/facebook/react-native/issues/934
|
* https://github.com/facebook/react-native/issues/934
|
||||||
*/
|
*/
|
||||||
function polyfillGlobal(name, newValue, scope = GLOBAL) {
|
function polyfillGlobal(name, newValue, scope = global) {
|
||||||
var descriptor = Object.getOwnPropertyDescriptor(scope, name) || {
|
var descriptor = Object.getOwnPropertyDescriptor(scope, name) || {
|
||||||
// jest for some bad reasons runs the polyfill code multiple times. In jest
|
// jest for some bad reasons runs the polyfill code multiple times. In jest
|
||||||
// environment, XmlHttpRequest doesn't exist so getOwnPropertyDescriptor
|
// environment, XmlHttpRequest doesn't exist so getOwnPropertyDescriptor
|
||||||
@ -70,7 +70,7 @@ function polyfillGlobal(name, newValue, scope = GLOBAL) {
|
|||||||
Object.defineProperty(scope, name, {...descriptor, value: newValue});
|
Object.defineProperty(scope, name, {...descriptor, value: newValue});
|
||||||
}
|
}
|
||||||
|
|
||||||
function polyfillLazyGlobal(name, valueFn, scope = GLOBAL) {
|
function polyfillLazyGlobal(name, valueFn, scope = global) {
|
||||||
if (scope[name] !== undefined) {
|
if (scope[name] !== undefined) {
|
||||||
const descriptor = Object.getOwnPropertyDescriptor(scope, name);
|
const descriptor = Object.getOwnPropertyDescriptor(scope, name);
|
||||||
const backupName = `original${name[0].toUpperCase()}${name.substr(1)}`;
|
const backupName = `original${name[0].toUpperCase()}${name.substr(1)}`;
|
||||||
@ -96,7 +96,7 @@ function polyfillLazyGlobal(name, valueFn, scope = GLOBAL) {
|
|||||||
/**
|
/**
|
||||||
* Polyfill a module if it is not already defined in `scope`.
|
* Polyfill a module if it is not already defined in `scope`.
|
||||||
*/
|
*/
|
||||||
function polyfillIfNeeded(name, polyfill, scope = GLOBAL, descriptor = {}) {
|
function polyfillIfNeeded(name, polyfill, scope = global, descriptor = {}) {
|
||||||
if (scope[name] === undefined) {
|
if (scope[name] === undefined) {
|
||||||
Object.defineProperty(scope, name, {...descriptor, value: polyfill});
|
Object.defineProperty(scope, name, {...descriptor, value: polyfill});
|
||||||
}
|
}
|
||||||
@ -141,8 +141,8 @@ function setUpTimers() {
|
|||||||
}
|
}
|
||||||
|
|
||||||
function setUpAlert() {
|
function setUpAlert() {
|
||||||
if (!GLOBAL.alert) {
|
if (!global.alert) {
|
||||||
GLOBAL.alert = function(text) {
|
global.alert = function(text) {
|
||||||
// Require Alert on demand. Requiring it too early can lead to issues
|
// Require Alert on demand. Requiring it too early can lead to issues
|
||||||
// with things like Platform not being fully initialized.
|
// with things like Platform not being fully initialized.
|
||||||
require('Alert').alert('Alert', '' + text);
|
require('Alert').alert('Alert', '' + text);
|
||||||
@ -169,12 +169,12 @@ function setUpXHR() {
|
|||||||
}
|
}
|
||||||
|
|
||||||
function setUpGeolocation() {
|
function setUpGeolocation() {
|
||||||
polyfillIfNeeded('navigator', {}, GLOBAL, {
|
polyfillIfNeeded('navigator', {}, global, {
|
||||||
writable: true,
|
writable: true,
|
||||||
enumerable: true,
|
enumerable: true,
|
||||||
configurable: true,
|
configurable: true,
|
||||||
});
|
});
|
||||||
polyfillLazyGlobal('geolocation', () => require('Geolocation'), GLOBAL.navigator);
|
polyfillLazyGlobal('geolocation', () => require('Geolocation'), global.navigator);
|
||||||
}
|
}
|
||||||
|
|
||||||
function setUpMapAndSet() {
|
function setUpMapAndSet() {
|
||||||
@ -185,7 +185,7 @@ function setUpMapAndSet() {
|
|||||||
}
|
}
|
||||||
|
|
||||||
function setUpProduct() {
|
function setUpProduct() {
|
||||||
Object.defineProperty(GLOBAL.navigator, 'product', {value: 'ReactNative'});
|
Object.defineProperty(global.navigator, 'product', {value: 'ReactNative'});
|
||||||
}
|
}
|
||||||
|
|
||||||
function setUpWebSockets() {
|
function setUpWebSockets() {
|
||||||
@ -200,13 +200,13 @@ function setUpProfile() {
|
|||||||
}
|
}
|
||||||
|
|
||||||
function setUpProcess() {
|
function setUpProcess() {
|
||||||
GLOBAL.process = GLOBAL.process || {};
|
global.process = global.process || {};
|
||||||
GLOBAL.process.env = GLOBAL.process.env || {};
|
global.process.env = global.process.env || {};
|
||||||
if (!GLOBAL.process.env.NODE_ENV) {
|
if (!global.process.env.NODE_ENV) {
|
||||||
GLOBAL.process.env.NODE_ENV = __DEV__ ? 'development' : 'production';
|
global.process.env.NODE_ENV = __DEV__ ? 'development' : 'production';
|
||||||
}
|
}
|
||||||
|
|
||||||
polyfillLazyGlobal('platform', () => require('Platform').OS, GLOBAL.process);
|
polyfillLazyGlobal('platform', () => require('Platform').OS, global.process);
|
||||||
}
|
}
|
||||||
|
|
||||||
function setUpDevTools() {
|
function setUpDevTools() {
|
||||||
|
@ -8,9 +8,7 @@
|
|||||||
*
|
*
|
||||||
* @providesModule ErrorUtils
|
* @providesModule ErrorUtils
|
||||||
*/
|
*/
|
||||||
/* eslint-disable consistent-this, global-strict */
|
/* eslint-disable strict */
|
||||||
|
|
||||||
var GLOBAL = this;
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* The particular require runtime that we are using looks for a global
|
* The particular require runtime that we are using looks for a global
|
||||||
@ -24,4 +22,4 @@ var GLOBAL = this;
|
|||||||
* that use it aren't just using a global variable, so simply export the global
|
* that use it aren't just using a global variable, so simply export the global
|
||||||
* variable here. ErrorUtils is originally defined in a file named error-guard.js.
|
* variable here. ErrorUtils is originally defined in a file named error-guard.js.
|
||||||
*/
|
*/
|
||||||
module.exports = GLOBAL.ErrorUtils;
|
module.exports = global.ErrorUtils;
|
||||||
|
@ -23,7 +23,6 @@ type RelayProfiler = {
|
|||||||
): void,
|
): void,
|
||||||
};
|
};
|
||||||
|
|
||||||
var GLOBAL = GLOBAL || this;
|
|
||||||
var TRACE_TAG_REACT_APPS = 1 << 17;
|
var TRACE_TAG_REACT_APPS = 1 << 17;
|
||||||
var TRACE_TAG_JSC_CALLS = 1 << 27;
|
var TRACE_TAG_JSC_CALLS = 1 << 27;
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user