-
Notifications
You must be signed in to change notification settings - Fork 630
/
parse.ts
27 lines (25 loc) · 890 Bytes
/
parse.ts
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
// Copyright 2018-2024 the Deno authors. All rights reserved. MIT license.
// This module is browser compatible.
import { isWindows } from "./_os.ts";
import type { ParsedPath } from "./_interface.ts";
import { parse as posixParse } from "./posix/parse.ts";
import { parse as windowsParse } from "./windows/parse.ts";
/**
* Return a `ParsedPath` object of the `path`. Use `format` to reverse the result.
*
* @example
* ```ts
* import { parse } from "https://deno.land/std@$STD_VERSION/path/mod.ts";
*
* const parsedPathObj = parse("/path/to/dir/script.ts");
* parsedPathObj.root; // "/"
* parsedPathObj.dir; // "/path/to/dir"
* parsedPathObj.base; // "script.ts"
* parsedPathObj.ext; // ".ts"
* parsedPathObj.name; // "script"
* ```
* @param path to process
*/
export function parse(path: string): ParsedPath {
return isWindows ? windowsParse(path) : posixParse(path);
}