summaryrefslogtreecommitdiff
path: root/ext/node/polyfills/path/common.ts
diff options
context:
space:
mode:
Diffstat (limited to 'ext/node/polyfills/path/common.ts')
-rw-r--r--ext/node/polyfills/path/common.ts39
1 files changed, 39 insertions, 0 deletions
diff --git a/ext/node/polyfills/path/common.ts b/ext/node/polyfills/path/common.ts
new file mode 100644
index 000000000..e4efe7cc4
--- /dev/null
+++ b/ext/node/polyfills/path/common.ts
@@ -0,0 +1,39 @@
+// Copyright 2018-2023 the Deno authors. All rights reserved. MIT license.
+// This module is browser compatible.
+
+import { SEP } from "internal:deno_node/polyfills/path/separator.ts";
+
+/** Determines the common path from a set of paths, using an optional separator,
+ * which defaults to the OS default separator.
+ *
+ * ```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}`;
+}