马宇豪
2024-07-16 f591c27b57e2418c9495bc02ae8cfff84d35bc18
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
const {parse, sep, normalize: norm} = require('path')
 
function* commonArrayMembers (a, b) {
  const [l, s] = a.length > b.length ? [a, b] : [b, a]
  for (const x of s) {
    if (x === l.shift())
      yield x
    else
      break
  }
}
 
const commonAncestorPath = (a, b) => a === b ? a
  : parse(a).root !== parse(b).root ? null
  : [...commonArrayMembers(norm(a).split(sep), norm(b).split(sep))].join(sep)
 
module.exports = (...paths) => paths.reduce(commonAncestorPath)