2024-04-27 17:11:57 -04:00
|
|
|
// Copyright 2018-2024 the Deno authors. All rights reserved. MIT license.
|
|
|
|
// This module is browser compatible.
|
|
|
|
|
2024-08-14 22:38:18 +01:00
|
|
|
import { normalize as posixNormalize } from "jsr:@std/path@^0.220.1/posix/normalize";
|
2024-04-27 17:11:57 -04:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Normalize the `URL`, resolving `'..'` and `'.'` segments and multiple
|
|
|
|
* `'/'`s into `'//'` after protocol and remaining into `'/'`.
|
|
|
|
*
|
|
|
|
* @example
|
|
|
|
* ```ts
|
|
|
|
* import { normalize } from "@std/url/normalize";
|
|
|
|
*
|
|
|
|
* console.log(normalize("https:///deno.land///std//assert//.//mod.ts").href);
|
|
|
|
* // Outputs: "https://deno.land/std/path/mod.ts"
|
|
|
|
*
|
|
|
|
* console.log(normalize("https://deno.land/std/assert/../async/retry.ts").href);
|
|
|
|
* // Outputs: "https://deno.land/std/async/retry.ts"
|
|
|
|
* ```
|
|
|
|
*
|
|
|
|
* @param url to be normalized
|
|
|
|
* @returns normalized URL
|
|
|
|
*/
|
|
|
|
export function normalize(url: string | URL): URL {
|
|
|
|
url = new URL(url);
|
|
|
|
url.pathname = posixNormalize(url.pathname);
|
|
|
|
return url;
|
|
|
|
}
|