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 c284b39b1ac13eaea8776b7b4f457c084dce5fb8..c794751ecd4448119ce33d661e694f83b3323f03 100644 --- a/lib/internal/modules/cjs/loader.js +++ b/lib/internal/modules/cjs/loader.js @@ -185,6 +185,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'); @@ -1464,10 +1471,12 @@ Module.prototype._compile = function(content, filename, loadAsESM = false) { this[kIsExecuting] = true; 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]); } this[kIsExecuting] = false; if (requireDepth === 0) { statCache = null; }