From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001 From: Cheng Zhao Date: Sun, 27 Mar 2016 14:42:26 +0900 Subject: Pass all globals through "require" (cherry picked from commit 7d015419cb7a0ecfe6728431a4ed2056cd411d62) diff --git a/lib/internal/modules/cjs/loader.js b/lib/internal/modules/cjs/loader.js index 2c48ff9512c225eb40cd34b844663e063b3695a9..e384e3e6c4e584132bb6a9831a554502f289133a 100644 --- a/lib/internal/modules/cjs/loader.js +++ b/lib/internal/modules/cjs/loader.js @@ -146,6 +146,13 @@ const { CHAR_FORWARD_SLASH, } = require('internal/constants'); +// Store the "global" variable from global scope into a local scope, so we can +// still reference it from this file even after we deleted the "global" variable +// from the global scope. +const localGlobal = (typeof global !== 'undefined') ? global : undefined; +// Do the same for "Buffer". +const localBuffer = (typeof Buffer !== 'undefined') ? Buffer : undefined; + const { isProxy, } = require('internal/util/types'); @@ -1364,10 +1371,12 @@ Module.prototype._compile = function(content, filename) { setHasStartedUserCJSExecution(); if (inspectorWrapper) { result = inspectorWrapper(compiledWrapper, thisValue, exports, - require, module, filename, dirname); + require, module, filename, dirname, + process, localGlobal, localBuffer); } else { result = ReflectApply(compiledWrapper, thisValue, - [exports, require, module, filename, dirname]); + [exports, require, module, filename, + dirname, process, localGlobal, localBuffer]); } if (requireDepth === 0) { statCache = null; } return result;