Skip to main content
This release is 8 versions behind 1.0.8 — the latest version of @std/path. Jump to latest

@std/path@1.0.0
Built and signed on GitHub Actions

Utilities for working with file system paths

This package works with Cloudflare Workers, Deno, Browsers
This package works with Cloudflare Workers
This package works with Deno
This package works with Browsers
JSR Score
94%
Published
9 months ago (1.0.0)
Package root>windows>to_file_url.ts
// Copyright 2018-2024 the Deno authors. All rights reserved. MIT license. // This module is browser compatible. import { encodeWhitespace } from "../_common/to_file_url.ts"; import { isAbsolute } from "./is_absolute.ts"; /** * Converts a path string to a file URL. * * @example Usage * ```ts * import { toFileUrl } from "@std/path/windows/to-file-url"; * import { assertEquals } from "@std/assert"; * * assertEquals(toFileUrl("\\home\\foo"), new URL("file:///home/foo")); * assertEquals(toFileUrl("C:\\Users\\foo"), new URL("file:///C:/Users/foo")); * assertEquals(toFileUrl("\\\\127.0.0.1\\home\\foo"), new URL("file://127.0.0.1/home/foo")); * ``` * @param path The path to convert. * @returns The file URL. */ export function toFileUrl(path: string): URL { if (!isAbsolute(path)) { throw new TypeError("Must be an absolute path."); } const [, hostname, pathname] = path.match( /^(?:[/\\]{2}([^/\\]+)(?=[/\\](?:[^/\\]|$)))?(.*)/, )!; const url = new URL("file:///"); url.pathname = encodeWhitespace(pathname!.replace(/%/g, "%25")); if (hostname !== undefined && hostname !== "localhost") { url.hostname = hostname; if (!url.hostname) { throw new TypeError("Invalid hostname."); } } return url; }