From f1b1b73c2ba4dc8d495ef044c7cc1477f4c49c1d Mon Sep 17 00:00:00 2001 From: guybedford Date: Fri, 24 Aug 2018 18:13:32 +0200 Subject: [PATCH] url: provide pathToFileURL and fileURLToPath PR-URL: https://github.com/nodejs/node/pull/22506 Reviewed-By: John-David Dalton Reviewed-By: Tiancheng "Timothy" Gu Reviewed-By: Matteo Collina Reviewed-By: Bradley Farias Reviewed-By: Joyee Cheung Reviewed-By: Gus Caplan --- doc/api/url.md | 43 +++++++++ lib/fs.js | 100 ++++++++++---------- lib/internal/fs/promises.js | 46 ++++----- lib/internal/fs/streams.js | 6 +- lib/internal/fs/watchers.js | 6 +- lib/internal/modules/cjs/loader.js | 8 +- lib/internal/modules/esm/default_resolve.js | 8 +- lib/internal/modules/esm/translators.js | 6 +- lib/internal/process/esm_loader.js | 6 +- lib/internal/url.js | 53 ++++++++--- lib/url.js | 8 +- test/common/inspector-helper.js | 6 +- test/parallel/test-url-pathtofileurl.js | 24 +++++ 13 files changed, 208 insertions(+), 112 deletions(-) create mode 100644 test/parallel/test-url-pathtofileurl.js diff --git a/doc/api/url.md b/doc/api/url.md index 571c3bdfdbfabb..cd817bf304b19e 100644 --- a/doc/api/url.md +++ b/doc/api/url.md @@ -880,6 +880,28 @@ console.log(url.domainToUnicode('xn--iñvalid.com')); // Prints an empty string ``` +### url.fileURLToPath(url) + +* `url` {URL | string} The file URL string or URL object to convert to a path. +* Returns: {string} The fully-resolved platform-specific Node.js file path. + +This function ensures the correct decodings of percent-encoded characters as +well as ensuring a cross-platform valid absolute path string. + +```js +new URL('file:///C:/path/').pathname; // Incorrect: /C:/path/ +fileURLToPath('file:///C:/path/'); // Correct: C:\path\ (Windows) + +new URL('file://nas/foo.txt').pathname; // Incorrect: /foo.txt +fileURLToPath('file://nas/foo.txt'); // Correct: \\nas\foo.txt (Windows) + +new URL('file:///你好.txt').pathname; // Incorrect: /%E4%BD%A0%E5%A5%BD.txt +fileURLToPath('file:///你好.txt'); // Correct: /你好.txt (POSIX) + +new URL('file:///hello world').pathname; // Incorrect: /hello%20world +fileURLToPath('file:///hello world'); // Correct: /hello world (POSIX) +``` + ### url.format(URL[, options])