std/path/posix/normalize_glob.ts

44 lines
1.3 KiB
TypeScript

// Copyright 2018-2024 the Deno authors. All rights reserved. MIT license.
// This module is browser compatible.
import type { GlobOptions } from "../_common/glob_to_reg_exp.ts";
import { normalize } from "./normalize.ts";
import { SEPARATOR_PATTERN } from "./constants.ts";
export type { GlobOptions };
/**
* Like normalize(), but doesn't collapse "**\/.." when `globstar` is true.
*
* @example Usage
* ```ts
* import { normalizeGlob } from "@std/path/posix/normalize-glob";
* import { assertEquals } from "@std/assert";
*
* const path = normalizeGlob("foo/bar/../*", { globstar: true });
* assertEquals(path, "foo/*");
* ```
*
* @param glob The glob to normalize.
* @param options The options to use.
* @returns The normalized path.
*/
export function normalizeGlob(
glob: string,
options: Pick<GlobOptions, "globstar"> = {},
): string {
const { globstar = false }: GlobOptions = options;
if (glob.match(/\0/g)) {
throw new Error(`Glob contains invalid characters: "${glob}"`);
}
if (!globstar) {
return normalize(glob);
}
const s = SEPARATOR_PATTERN.source;
const badParentPattern = new RegExp(
`(?<=(${s}|^)\\*\\*${s})\\.\\.(?=${s}|$)`,
"g",
);
return normalize(glob.replace(badParentPattern, "\0")).replace(/\0/g, "..");
}