doc: update `path.format` description and examples

* removed pseudo-code
* added info on which properties have priority
* modified examples to show ignored properties

PR-URL: https://github.com/nodejs/node/pull/10046
Reviewed-By: James M Snell <jasnell@gmail.com>
Reviewed-By: Sam Roberts <vieuxtech@gmail.com>
pull/10143/head
anoff 2016-12-01 11:54:46 -06:00 committed by Rich Trott
parent 1e4b9a1450
commit 2d0ce510e8
1 changed files with 12 additions and 26 deletions

View File

@ -182,26 +182,20 @@ added: v0.11.15
The `path.format()` method returns a path string from an object. This is the The `path.format()` method returns a path string from an object. This is the
opposite of [`path.parse()`][]. opposite of [`path.parse()`][].
The following process is used when constructing the path string: When providing properties to the `pathObject` remember that there are
combinations where one property has priority over another:
* `output` is set to an empty string. * `pathObject.root` is ignored if `pathObject.dir` is provided
* If `pathObject.dir` is specified, `pathObject.dir` is appended to `output` * `pathObject.ext` and `pathObject.name` are ignored if `pathObject.base` exists
followed by the value of `path.sep`;
* Otherwise, if `pathObject.root` is specified, `pathObject.root` is appended
to `output`.
* If `pathObject.base` is specified, `pathObject.base` is appended to `output`;
* Otherwise:
* If `pathObject.name` is specified, `pathObject.name` is appended to `output`
* If `pathObject.ext` is specified, `pathObject.ext` is appended to `output`.
* Return `output`
For example, on POSIX: For example, on POSIX:
```js ```js
// If `dir` and `base` are provided, // If `dir`, `root` and `base` are provided,
// `${dir}${path.sep}${base}` // `${dir}${path.sep}${base}`
// will be returned. // will be returned. `root` is ignored.
path.format({ path.format({
root: '/ignored',
dir: '/home/user/dir', dir: '/home/user/dir',
base: 'file.txt' base: 'file.txt'
}); });
@ -209,10 +203,11 @@ path.format({
// `root` will be used if `dir` is not specified. // `root` will be used if `dir` is not specified.
// If only `root` is provided or `dir` is equal to `root` then the // If only `root` is provided or `dir` is equal to `root` then the
// platform separator will not be included. // platform separator will not be included. `ext` will be ignored.
path.format({ path.format({
root: '/', root: '/',
base: 'file.txt' base: 'file.txt',
ext: 'ignored'
}); });
// Returns: '/file.txt' // Returns: '/file.txt'
@ -223,23 +218,14 @@ path.format({
ext: '.txt' ext: '.txt'
}); });
// Returns: '/file.txt' // Returns: '/file.txt'
// `base` will be returned if `dir` or `root` are not provided.
path.format({
base: 'file.txt'
});
// Returns: 'file.txt'
``` ```
On Windows: On Windows:
```js ```js
path.format({ path.format({
root : "C:\\", dir : "C:\\path\\dir",
dir : "C:\\path\\dir", base : "file.txt"
base : "file.txt",
ext : ".txt",
name : "file"
}); });
// Returns: 'C:\\path\\dir\\file.txt' // Returns: 'C:\\path\\dir\\file.txt'
``` ```