Welcome to mirror list, hosted at ThFree Co, Russian Federation.

case-insensitive-map.js « lib « arborist « @npmcli « node_modules « npm « deps - github.com/nodejs/node.git - Unnamed repository; edit this file 'description' to name the repository.
summaryrefslogtreecommitdiff
blob: 8254c3f7a55e99fd167147df0b46e61867484933 (plain)
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
// 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.

const _keys = Symbol('keys')
const _normKey = Symbol('normKey')
const normalize = s => s.normalize('NFKD').toLowerCase()
const OGMap = Map
module.exports = class Map extends OGMap {
  constructor (items = []) {
    super()
    this[_keys] = new OGMap()
    for (const [key, val] of items)
      this.set(key, val)
  }

  [_normKey] (key) {
    return typeof key === 'string' ? normalize(key) : key
  }

  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))
  }
}