diff options
| author | Kitson Kelly <me@kitsonkelly.com> | 2020-03-31 02:36:55 +1100 |
|---|---|---|
| committer | GitHub <noreply@github.com> | 2020-03-30 11:36:55 -0400 |
| commit | 7670a13f8a036589f200296693957e4e24ef769a (patch) | |
| tree | e8f389a6b9643195189a4aa1a7b9dbe930774543 /std/path/common.ts | |
| parent | d795d3436246b609c572921ea4511fbde37f0ff3 (diff) | |
feat: Add common to std/path (#4527)
Diffstat (limited to 'std/path/common.ts')
| -rw-r--r-- | std/path/common.ts | 38 |
1 files changed, 38 insertions, 0 deletions
diff --git a/std/path/common.ts b/std/path/common.ts new file mode 100644 index 000000000..0a4de3f0c --- /dev/null +++ b/std/path/common.ts @@ -0,0 +1,38 @@ +// Copyright 2018-2020 the Deno authors. All rights reserved. MIT license. + +import { SEP } from "./constants.ts"; + +/** Determines the common path from a set of paths, using an optional separator, + * which defaults to the OS default separator. + * + * import { common } from "https://deno.land/std/path/mod.ts"; + * const p = common([ + * "./deno/std/path/mod.ts", + * "./deno/std/fs/mod.ts", + * ]); + * console.log(p); // "./deno/std/" + * + */ +export function common(paths: string[], sep = SEP): string { + const [first = "", ...remaining] = paths; + if (first === "" || remaining.length === 0) { + return first.substring(0, first.lastIndexOf(sep) + 1); + } + const parts = first.split(sep); + + let endOfPrefix = parts.length; + for (const path of remaining) { + const compare = path.split(sep); + for (let i = 0; i < endOfPrefix; i++) { + if (compare[i] !== parts[i]) { + endOfPrefix = i; + } + } + + if (endOfPrefix === 0) { + return ""; + } + } + const prefix = parts.slice(0, endOfPrefix).join(sep); + return prefix.endsWith(sep) ? prefix : `${prefix}${sep}`; +} |
