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 7bbd59e16330b59f6c71aa8e6ff59659e42f6cee..276ab42c22b796ee07ce66744187adca6a8b8da4 100644 --- a/lib/internal/modules/cjs/loader.js +++ b/lib/internal/modules/cjs/loader.js @@ -148,6 +148,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'); @@ -1353,10 +1360,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;