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:
Janic Duplessis 2016-04-29 16:14:55 -07:00 committed by Facebook Github Bot 9
parent 373537b281
commit 169cfb5a52
3 changed files with 17 additions and 20 deletions

View File

@ -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() {

View File

@ -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;

View File

@ -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;