This release is 8 versions behind 1.0.8 — the latest version of @std/path. Jump to latest
Built and signed on GitHub ActionsBuilt and signed on GitHub Actions
Built and signed on GitHub Actions
Utilities for working with file system paths
This package works with Cloudflare Workers, Deno, Browsers


JSR Score
94%
Published
9 months ago (1.0.0)
// 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; }