diff --git a/doc/api/deprecations.md b/doc/api/deprecations.md index 84e4ed2604f0b2..0928803fc6281c 100644 --- a/doc/api/deprecations.md +++ b/doc/api/deprecations.md @@ -3554,6 +3554,9 @@ Please use `value instanceof WebAssembly.Module` instead. -Type: Documentation-only +Type: Runtime The [`dirent.path`][] is deprecated due to its lack of consistency across release lines. Please use [`dirent.parentPath`][] instead. diff --git a/doc/api/fs.md b/doc/api/fs.md index d6afc9d5ea9403..18138be8a77ee9 100644 --- a/doc/api/fs.md +++ b/doc/api/fs.md @@ -6763,13 +6763,17 @@ deprecated: - v21.5.0 - v20.12.0 - v18.20.0 +changes: + - version: REPLACEME + pr-url: https://github.com/nodejs/node/pull/51050 + description: Accessing this property emits a warning. It is now read-only. --> > Stability: 0 - Deprecated: Use [`dirent.parentPath`][] instead. * {string} -Alias for `dirent.parentPath`. +Alias for `dirent.parentPath`. Read-only. ### Class: `fs.FSWatcher` diff --git a/lib/internal/fs/utils.js b/lib/internal/fs/utils.js index 18c6f8d419d47a..a5f1b499e3b9c3 100644 --- a/lib/internal/fs/utils.js +++ b/lib/internal/fs/utils.js @@ -166,7 +166,6 @@ class Dirent { constructor(name, type, path) { this.name = name; this.parentPath = path; - this.path = path; this[kType] = type; } @@ -215,6 +214,15 @@ for (const name of ReflectOwnKeys(Dirent.prototype)) { }; } +ObjectDefineProperty(Dirent.prototype, 'path', { + __proto__: null, + get: deprecate(function() { + return this.parentPath; + }, 'dirent.path is deprecated in favor of dirent.parentPath', 'DEP0178'), + configurable: true, + enumerable: false, +}); + function copyObject(source) { const target = {}; for (const key in source) diff --git a/test/parallel/test-fs-utils-get-dirents.js b/test/parallel/test-fs-utils-get-dirents.js index 9c53a4146a6768..dfc851090b269d 100644 --- a/test/parallel/test-fs-utils-get-dirents.js +++ b/test/parallel/test-fs-utils-get-dirents.js @@ -88,6 +88,11 @@ const filename = 'foo'; common.mustCall((err, dirent) => { assert.strictEqual(err, null); assert.strictEqual(dirent.name, filenameBuffer); + common.expectWarning( + 'DeprecationWarning', + 'dirent.path is deprecated in favor of dirent.parentPath', + 'DEP0178'); + assert.deepStrictEqual(dirent.path, Buffer.from(tmpdir.resolve(`${filename}/`))); }, )); }