马宇豪
2024-07-16 f591c27b57e2418c9495bc02ae8cfff84d35bc18
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
// package children are represented with a Map object, but many file systems
// are case-insensitive and unicode-normalizing, so we need to treat
// node.children.get('FOO') and node.children.get('foo') as the same thing.
 
module.exports = class CIMap extends Map {
  #keys = new Map()
 
  constructor (items = []) {
    super()
    for (const [key, val] of items) {
      this.set(key, val)
    }
  }
 
  #normKey (key) {
    if (typeof key !== 'string') {
      return key
    }
    return key.normalize('NFKD').toLowerCase()
  }
 
  get (key) {
    const normKey = this.#normKey(key)
    return this.#keys.has(normKey) ? super.get(this.#keys.get(normKey))
      : undefined
  }
 
  set (key, val) {
    const normKey = this.#normKey(key)
    if (this.#keys.has(normKey)) {
      super.delete(this.#keys.get(normKey))
    }
    this.#keys.set(normKey, key)
    return super.set(key, val)
  }
 
  delete (key) {
    const normKey = this.#normKey(key)
    if (this.#keys.has(normKey)) {
      const prevKey = this.#keys.get(normKey)
      this.#keys.delete(normKey)
      return super.delete(prevKey)
    }
  }
 
  has (key) {
    const normKey = this.#normKey(key)
    return this.#keys.has(normKey) && super.has(this.#keys.get(normKey))
  }
}