Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/flex-development/pathe

Universal drop-in replacement for node:path
https://github.com/flex-development/pathe

backslash filesystem forwardslash linux macos node nodejs path posix slash typescript windows

Last synced: 17 days ago
JSON representation

Universal drop-in replacement for node:path

Awesome Lists containing this project

README

        

# pathe

[![github release](https://img.shields.io/github/v/release/flex-development/pathe.svg?include_prereleases\&sort=semver)](https://github.com/flex-development/pathe/releases/latest)
[![npm](https://img.shields.io/npm/v/@flex-development/pathe.svg)](https://npmjs.com/package/@flex-development/pathe)
[![codecov](https://codecov.io/gh/flex-development/pathe/branch/main/graph/badge.svg?token=R2TPEBGWXB)](https://codecov.io/gh/flex-development/pathe)
[![license](https://img.shields.io/github/license/flex-development/pathe.svg)](LICENSE.md)
[![conventional commits](https://img.shields.io/badge/-conventional%20commits-fe5196?logo=conventional-commits\&logoColor=ffffff)](https://conventionalcommits.org)
[![typescript](https://img.shields.io/badge/-typescript-3178c6?logo=typescript\&logoColor=ffffff)](https://typescriptlang.org)
[![vitest](https://img.shields.io/badge/-vitest-6e9f18?style=flat\&logo=vitest\&logoColor=ffffff)](https://vitest.dev)
[![yarn](https://img.shields.io/badge/-yarn-2c8ebb?style=flat\&logo=yarn\&logoColor=ffffff)](https://yarnpkg.com)

Universal drop-in replacement for [`node:path`][node-path]

## Contents

- [What is this?](#what-is-this)
- [When should I use this?](#when-should-i-use-this)
- [Install](#install)
- [API](#api)
- [Types](#types)
- [Contribute](#contribute)

## What is this?

This package is a universal drop-in replacement for Node.js' [`path`][node-path] module.

It enforces consistency between POSIX and Windows operating systems and also provides additional utilities for working
with file URLs, paths, and extensions.

## When should I use this?

For [historical reasons][historical-reasons], Windows followed MS-DOS and used backslashes (`\`) to separate path
components, as opposed to the forwardslashes (`/`) used by POSIX operating systems. Even though Windows operating
systems now support both separators, there are still discrepancies between operating systems when using Node.js' `path`
module:

> The default operation of the `node:path` module varies based on the operating system on which a Node.js application is
> running. Specifically, when running on a Windows operating system, the `node:path` module will assume that
> Windows-style paths are being used. – [*Windows vs. POSIX*][windows-vs-posix]

This package enforces consistency between operating systems by ensuring paths are POSIX-compliant. With support for both
[drive][drive-path] and [UNC paths][unc-path] as well, platform-specific modules like
[`node:path/posix`][node-path-posix] and [`node:path/win32`][node-path-win32] are no longer needed.

> ~~To achieve consistent results when working with Windows file paths on any operating system,
> use [`path.win32`][node-path-win32].~~
> ~~To achieve consistent results when working with POSIX file paths on any operating system,
> use [`path.posix`][node-path-posix].~~

**To achieve consistent results when working with Windows file paths on any operating system, use `pathe`. To achieve
consistent results when working with POSIX file paths on any operating system, use `pathe`. \:blush:**

## Install

This package is [ESM only][esm].

In Node.js (version 18+) with [yarn][]:

```sh
yarn add @flex-development/pathe
```



See Git - Protocols | Yarn
 for details regarding installing from Git.

In Deno with [`esm.sh`][esmsh]:

```ts
import { parse } from 'https://esm.sh/@flex-development/pathe'
```

In browsers with [`esm.sh`][esmsh]:

```html

import { parse } from 'https://esm.sh/@flex-development/pathe'

```

## Use

```ts
import {
addExt,
basename,
changeExt,
cwd,
delimiter,
dirname,
dot,
extToValue,
extname,
fileURLToPath,
format,
formatExt,
isAbsolute,
isDeviceRoot,
isSep,
isURL,
join,
matchesGlob,
normalize,
parse,
pathToFileURL,
relative,
removeExt,
resolve,
resolveWith,
root,
sep,
toNamespacedPath,
toPath,
toPosix
} from '@flex-development/pathe'
```

## API

This package exports the following identifiers:

- [`addExt`](./src/lib/add-ext.mts)
- [`basename`](./src/lib/basename.mts)
- [`changeExt`](./src/lib/change-ext.mts)
- [`cwd`](./src/lib/cwd.mts)
- [`delimiter`](./src/lib/delimiter.mts)
- [`dirname`](./src/lib/dirname.mts)
- [`dot`](./src/lib/dot.mts)
- [`extToValue`](./src/lib/ext-to-value.mts)
- [`extname`](./src/lib/extname.mts)
- [`extnames`](./src/lib/extnames.mts)
- [`fileURLToPath`](./src/lib/file-url-to-path.mts)
- [`formatExt`](./src/lib/format-ext.mts)
- [`format`](./src/lib/format.mts)
- [`isAbsolute`](./src/lib/is-absolute.mts)
- [`isDeviceRoot`](./src/lib/is-device-root.mts)
- [`isSep`](./src/lib/is-sep.mts)
- [`isURL`](./src/lib/is-url.mts)
- [`join`](./src/lib/join.mts)
- [`matchesGlob`](./src/lib/matches-glob.mts)
- [`normalize`](./src/lib/normalize.mts)
- [`parse`](./src/lib/parse.mts)
- [`pathToFileURL`](./src/lib/path-to-file-url.mts)
- [`posix`](./src/pathe.mts)
- [`relative`](./src/lib/relative.mts)
- [`removeExt`](./src/lib/remove-ext.mts)
- [`resolveWith`](./src/lib/resolve-with.mts)
- [`resolve`](./src/lib/resolve.mts)
- [`root`](./src/lib/root.mts)
- [`sep`](./src/lib/sep.mts)
- [`toNamespacedPath`](./src/lib/to-namespaced-path.mts)
- [`toPath`](./src/lib/to-path.mts)
- [`toPosix`](./src/lib/to-posix.mts)
- [`win32`](./src/pathe.mts)

The default export is `pathe`.

> Documentation website coming soon.

## Types

This package is fully typed with [TypeScript][].

- [`Cwd`](src/types/cwd.mts)
- [`Delimiter`](src/types/delimiter.mts)
- [`DeviceRoot`](src/types/device-root.mts)
- [`Dot`](src/types/dot.mts)
- [`DriveLetter`](src/types/drive-letter.mts)
- [`EmptyString`](src/types/empty-string.mts)
- [`Ext`](src/types/ext.mts)
- [`FormatInputPathObject`](src/interfaces/format-input-path-object.mts)
- [`ParsedPath`](src/interfaces/parsed-path.mts)
- [`Pathe`](src/interfaces/pathe.mts)
- [`PlatformOptions`](src/interfaces/platform-options.mts)
- [`PlatformPath`](src/interfaces/platform-path.mts)
- [`PosixDelimiter`](src/types/delimiter-posix.mts)
- [`PosixPlatformPath`](src/interfaces/platform-path-posix.mts)
- [`PosixSep`](src/types/sep-posix.mts)
- [`Sep`](src/types/sep.mts)
- [`WindowsDelimiter`](src/types/delimiter-windows.mts)
- [`WindowsPlatformPath`](src/interfaces/platform-path-windows.mts)
- [`WindowsSep`](src/types/sep-windows.mts)

## Contribute

See [`CONTRIBUTING.md`](CONTRIBUTING.md).

This project has a [code of conduct](./CODE_OF_CONDUCT.md). By interacting with this repository, organization, or
community you agree to abide by its terms.

[drive-path]: https://learn.microsoft.com/windows/win32/fileio/naming-a-file#naming-conventions

[esm]: https://gist.github.com/sindresorhus/a39789f98801d908bbc7ff3ecc99d99c

[esmsh]: https://esm.sh

[historical-reasons]: https://learn.microsoft.com/archive/blogs/larryosterman/why-is-the-dos-path-character

[node-path-posix]: https://nodejs.org/api/path.html#pathposix

[node-path-win32]: https://nodejs.org/api/path.html#pathwin32

[node-path]: https://nodejs.org/api/path.html

[typescript]: https://www.typescriptlang.org

[unc-path]: https://learn.microsoft.com/dotnet/standard/io/file-path-formats#unc-paths

[windows-vs-posix]: https://nodejs.org/api/path.html#windows-vs-posix

[yarn]: https://yarnpkg.com