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 451b7c2195e7ad3ab0bde95259e054dc431d7de9..d49941881e6cfd8647a6d44a57e0daaf1c874702 100644 --- a/lib/internal/modules/cjs/loader.js +++ b/lib/internal/modules/cjs/loader.js @@ -182,6 +182,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'); @@ -1541,10 +1548,12 @@ Module.prototype._compile = function(content, filename, format) { 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; }