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 b077ee386bb40ea32208fc6655de88a3449b7eb2..d4b70bab5e89300bfe6305263d556c986380e2e0 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'); @@ -1371,10 +1378,12 @@ Module.prototype._compile = function(content, filename) { if (requireDepth === 0) { statCache = new SafeMap(); } 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]); } hasLoadedAnyUserCJSModule = true; if (requireDepth === 0) { statCache = null; }