-
Notifications
You must be signed in to change notification settings - Fork 29.7k
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
url: expose pathToFileURL and fileURLToPath #22506
Changes from 13 commits
4d95ca1
0d9c808
0b784b4
6479897
09bc85a
c073384
d36d1f9
47d9efa
44de7c0
ee7b01d
3bba43e
d1dfe98
a9dc0ce
3394901
11b2606
d921fef
8d95ddb
87d7a73
File filter
Filter by extension
Conversations
Jump to
Diff view
Diff view
There are no files selected for viewing
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -880,6 +880,30 @@ 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: {URL} 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. | ||
|
||
For example: | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. IIRC, we usually avoid such introductive notes as redundant. There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Still here) |
||
|
||
```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]) | ||
<!-- YAML | ||
added: v7.6.0 | ||
|
@@ -906,8 +930,6 @@ string serializations of the URL. These are not, however, customizable in | |
any way. The `url.format(URL[, options])` method allows for basic customization | ||
of the output. | ||
|
||
For example: | ||
|
||
```js | ||
const myURL = new URL('https://a:b@你好你好?abc#foo'); | ||
|
||
|
@@ -921,6 +943,27 @@ console.log(url.format(myURL, { fragment: false, unicode: true, auth: false })); | |
// Prints 'https://你好你好/?abc' | ||
``` | ||
|
||
### url.pathToFileURL(path) | ||
|
||
* `path` {string} The path to convert to a File URL. | ||
* Returns: {URL} The file URL object. | ||
|
||
This function ensures that `path` is resolved absolutely, and that the URL | ||
control characters are correctly encoded when converting into a File URL. | ||
|
||
```js | ||
new URL(__filename); // Incorrect: throws (POSIX) | ||
new URL(__filename); // Incorrect: C:\... (Windows) | ||
pathToFileURL(__filename); // Correct: file:///... (POSIX) | ||
pathToFileURL(__filename); // Correct: file:///C:/... (Windows) | ||
|
||
new URL('/foo#1', 'file:'); // Incorrect: file:///foo#1 | ||
pathToFileURL('/foo#1'); // Correct: file:///foo%231 (POSIX) | ||
|
||
new URL('/some/path%.js', 'file:'); // Incorrect: file:///some/path% | ||
pathToFileURL('/some/path%.js'); // Correct: file:///some/path%25 (POSIX) | ||
``` | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Can you please add an example that uses the new API instead? |
||
|
||
## Legacy URL API | ||
|
||
### Legacy `urlObject` | ||
|
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
actually whoops this should be
{string}
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Ahhh... thank you!