From 9a0bcfc4522b233c5506da91b01b6d649cfe5020 Mon Sep 17 00:00:00 2001 From: Anna Henningsen Date: Fri, 30 Sep 2016 16:16:28 +0200 Subject: [PATCH] fs: export `realpathCacheKey` from `internal/fs` MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Move the internally defined symbol `fs.realpathCacheKey` to the internal fs module, where it’s more appropriate. The symbol was recently added in c084287a608ef, but since `internal/fs` is only available in the v7.x branch, this needs to be a separate follow-up change. PR-URL: https://github.com/nodejs/node/pull/8862 Reviewed-By: Colin Ihrig Reviewed-By: James M Snell --- lib/fs.js | 6 +----- lib/internal/fs.js | 2 ++ lib/module.js | 6 ++---- 3 files changed, 5 insertions(+), 9 deletions(-) diff --git a/lib/fs.js b/lib/fs.js index e22838da156fb2..a241e6c456e4a7 100644 --- a/lib/fs.js +++ b/lib/fs.js @@ -1455,10 +1455,6 @@ function encodeRealpathResult(result, options, err) { } } -// This is removed from the fs exports in lib/module.js in order to make -// sure that this stays internal. -const realpathCacheKey = fs.realpathCacheKey = Symbol('realpathCacheKey'); - fs.realpathSync = function realpathSync(p, options) { options = getOptions(options, {}); nullCheck(p); @@ -1468,7 +1464,7 @@ fs.realpathSync = function realpathSync(p, options) { const seenLinks = {}; const knownHard = {}; - const cache = options[realpathCacheKey]; + const cache = options[internalFS.realpathCacheKey]; const original = p; const maybeCachedResult = cache && cache.get(p); diff --git a/lib/internal/fs.js b/lib/internal/fs.js index 89ad30b78ce916..881679f99c4000 100644 --- a/lib/internal/fs.js +++ b/lib/internal/fs.js @@ -96,3 +96,5 @@ SyncWriteStream.prototype.destroy = function() { }; exports.SyncWriteStream = SyncWriteStream; + +exports.realpathCacheKey = Symbol('realpathCacheKey'); diff --git a/lib/module.js b/lib/module.js index 2da3dca35ae000..09c4b85b9e5599 100644 --- a/lib/module.js +++ b/lib/module.js @@ -6,6 +6,7 @@ const internalModule = require('internal/module'); const vm = require('vm'); const assert = require('assert').ok; const fs = require('fs'); +const internalFS = require('internal/fs'); const path = require('path'); const internalModuleReadFile = process.binding('fs').internalModuleReadFile; const internalModuleStat = process.binding('fs').internalModuleStat; @@ -113,9 +114,6 @@ function tryPackage(requestPath, exts, isMain) { // Set to an empty Map to reset. const realpathCache = new Map(); -const realpathCacheKey = fs.realpathCacheKey; -delete fs.realpathCacheKey; - // check if the file exists and is not a directory // if using --preserve-symlinks and isMain is false, // keep symlinks intact, otherwise resolve to the @@ -130,7 +128,7 @@ function tryFile(requestPath, isMain) { function toRealPath(requestPath) { return fs.realpathSync(requestPath, { - [realpathCacheKey]: realpathCache + [internalFS.realpathCacheKey]: realpathCache }); }