马宇豪
2024-08-29 893ff90c6e21fa3a5241a8ae9b33836037cd5912
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)