File paths library. All you need to work with paths. Tiny drop-in replacement for 'path'. Works in Node, Browser, and Deno.
npm install --save patha
patha
is tiny and treeshakable.
Automatic (depends on your build system)
import * as patha from "patha"
Node
import * as patha from "patha/dist/index.node.mjs"
Node CJS
const patha = require("patha/dist/index.node.cjs")
Browser
import * as patha from "patha/dist/index.browser.mjs"
Browser Legacy
import * as patha from "patha/dist/index.browser.legacy.js"
Deno
import * as patha from "patha/dist/index.deno.mjs"
patha
is a drop-replacement for path
, which is explained in the Nodejs documentation.
import {
basename,
delimiter,
dirname,
extname,
format,
isAbsolute,
join,
normalize,
parse,
posix,
relative,
resolve,
sep,
toNamespacedPath,
win32,
} from "patha"
Additionally, patha
supports the following functions:
Add bin extension to the given binary name.
Parameters:
- name (
string
) - The name you want to add the shell extension to - win_ext (
string
) - Defaults to.exe
on Windows - other_ext (
string
) - Defaults to""
On other platforms.
returns: string
import { addExeExt } from "patha"
addExeExt("path/to/file-name") // gives "path/to/file-name.exe" on Windows and "path/to/file-name" on others
Adds a prefix to the start of the name of the given path
Parameters:
- path (
string
) - The given file path - prefix (
string
) - The prefix to add to the start of the file name
returns: string
import { addNamePrefix } from "patha"
addNamePrefix("path/to/file-name.ext", "new-") // gives "path/to/new-file-name.ext"
Adds a suffix to the end of the name of the given path
Parameters:
- path (
string
) - The given file path - suffix (
string
) - The suffix to add to the end of the file name
returns: string
import { addNameSuffix } from "patha"
addNameSuffix("path/to/file-name.ext", "-old") // gives "path/to/file-name-old.ext"
addNameSuffix("path/to/file-name.ext", ".test") // gives "path/to/file-name.test.ext"
Add a native shell extension to the given name.
Parameters:
- name (
string
) - The name you want to add the shell extension to - win_ext (
string
) -.cmd
on Windows - other_ext (
string
) -.sh
On others.
returns: string
import { addShExt } from "patha"
addShExt("path/to/file-name") // gives "path/to/file-name.cmd" on Windows and "path/to/file-name.sh" on others
addShExt("path/to/file-name", ".bat") // gives "path/to/file-name.bat" on Windows and "path/to/file-name.sh" on others
Prefix a ./
for unix shell and nothing for cmd
.
Parameters:
- path (
string
) - The given path
returns: string
import { addShRelativePrefix } from "patha"
addShRelativePrefix("some/file-name") // gives "some/file-name" on Windows and "./some/file-name" on others.
Get the name of the given file path.
By default the file extension is included in the returned name. To remove the extension, set the second parameter to false
.
Parameters:
- path (
string
) - The given file path - includeExtension (
boolean
) - If the name should include the file extension as well
returns: string
import { name } from "patha"
name("path/to/file.md") // gives "file.md"
name("path/to/file.md", false) // gives "file"
Normalizes the path and removes the trailing slashes.
Parameters:
- path (
string
) - The given file path
returns: string
import { normalize, normalizeTrim } from "patha"
normalizeTrim("/foo/bar//baz/asdf/hello/../") // gives "/foo/bar/baz/asdf"
normalize("/foo/bar//baz/asdf/hello/../") // gives "/foo/bar/baz/asdf/"
Remove a path's extension.
Parameters:
- path (
string
) - The given path
returns: string
import { removeExt } from "patha"
removeExt("some/dir/file.ext") // gives "some/dir/file"
Replaces the extension from path with extension and returns the updated path string.
Does not replace the extension if path is not a string or is empty.
Parameters:
- path (
string
) - The given path - extension (
string
) - The extension to replace
returns: any
import { replaceExt } from "patha"
replaceExt("path/to/file.md", ".html") // gives "path/to/file.html"
Check if a path is inside another path.
Note that relative paths are resolved against process.cwd()
to make them absolute.
This function does not check if the paths exist and it only works with strings.
Parameters:
- childPath (
string
) - parentPath (
string
)
returns: boolean
import { isPathInside } from "patha"
isPathInside("a/b/c", "a/b")
//=> true
isPathInside("a/b/c", "x/y")
//=> false
isPathInside("a/b/c", "a/b/c")
//=> false
isPathInside("/Users/some/dev/aa", "/Users/some")
//=> true
You can sponsor my work here:
https://github.com/sponsors/aminya
Pull requests, issues and feature requests are welcome. See the Contributing guide.