From 5b0fd7e8e4f67afa38c9a48e1cd4ea48e8c6666d Mon Sep 17 00:00:00 2001 From: James M Snell Date: Mon, 27 Feb 2017 09:53:26 -0800 Subject: [PATCH] lib: avoid using forEach PR-URL: https://github.com/nodejs/node/pull/11582 Reviewed-By: Matteo Collina Reviewed-By: Colin Ihrig --- lib/internal/bootstrap_node.js | 65 +++++++++++++++++++++------------- 1 file changed, 40 insertions(+), 25 deletions(-) diff --git a/lib/internal/bootstrap_node.js b/lib/internal/bootstrap_node.js index ba5cf949d7bd09..f29f7a647a4bd3 100644 --- a/lib/internal/bootstrap_node.js +++ b/lib/internal/bootstrap_node.js @@ -208,14 +208,14 @@ global.process = process; const util = NativeModule.require('util'); - // Deprecate GLOBAL and root - ['GLOBAL', 'root'].forEach(function(name) { - // getter - const get = util.deprecate(function() { + function makeGetter(name) { + return util.deprecate(function() { return this; }, `'${name}' is deprecated, use 'global'`, 'DEP0016'); - // setter - const set = util.deprecate(function(value) { + } + + function makeSetter(name) { + return util.deprecate(function(value) { Object.defineProperty(this, name, { configurable: true, writable: true, @@ -223,8 +223,19 @@ value: value }); }, `'${name}' is deprecated, use 'global'`, 'DEP0016'); - // define property - Object.defineProperty(global, name, { get, set, configurable: true }); + } + + Object.defineProperties(global, { + GLOBAL: { + configurable: true, + get: makeGetter('GLOBAL'), + set: makeSetter('GLOBAL') + }, + root: { + configurable: true, + get: makeGetter('root'), + set: makeSetter('root') + } }); global.Buffer = NativeModule.require('buffer').Buffer; @@ -328,27 +339,31 @@ // With no argument, getVersion() returns a comma separated list // of possible types. const versionTypes = icu.getVersion().split(','); - versionTypes.forEach((name) => { - // Copied from module.js:addBuiltinLibsToObject + + function makeGetter(name) { + return () => { + // With an argument, getVersion(type) returns + // the actual version string. + const version = icu.getVersion(name); + // Replace the current getter with a new property. + delete process.versions[name]; + Object.defineProperty(process.versions, name, { + value: version, + writable: false, + enumerable: true + }); + return version; + }; + } + + for (var n = 0; n < versionTypes.length; n++) { + var name = versionTypes[n]; Object.defineProperty(process.versions, name, { configurable: true, enumerable: true, - get: () => { - // With an argument, getVersion(type) returns - // the actual version string. - const version = icu.getVersion(name); - // Replace the current getter with a new - // property. - delete process.versions[name]; - Object.defineProperty(process.versions, name, { - value: version, - writable: false, - enumerable: true - }); - return version; - } + get: makeGetter(name) }); - }); + } } function tryGetCwd(path) {