2018-08-16 22:30:59 +00:00
|
|
|
/*
|
2021-02-04 22:04:35 +00:00
|
|
|
* Copyright (c) 2010-2021 Tim Düsterhus.
|
2018-08-16 22:30:59 +00:00
|
|
|
*
|
|
|
|
* Use of this software is governed by the Business Source License
|
|
|
|
* included in the LICENSE file.
|
|
|
|
*
|
2022-03-10 17:56:18 +00:00
|
|
|
* Change Date: 2026-03-10
|
2018-08-16 22:30:59 +00:00
|
|
|
*
|
|
|
|
* On the date above, in accordance with the Business Source
|
|
|
|
* License, use of this software will be governed by version 2
|
|
|
|
* or later of the General Public License.
|
|
|
|
*/
|
|
|
|
|
2020-11-01 16:41:19 +00:00
|
|
|
define([], function () {
|
|
|
|
'use strict'
|
2018-08-16 22:30:59 +00:00
|
|
|
|
|
|
|
const s = Symbol('s')
|
|
|
|
const start = Symbol('start')
|
|
|
|
|
|
|
|
class LRU {
|
|
|
|
constructor() {
|
|
|
|
this[s] = new Map()
|
|
|
|
this[start] = undefined
|
|
|
|
}
|
|
|
|
|
|
|
|
add(value) {
|
2020-11-01 16:41:19 +00:00
|
|
|
if (this[start] && this[start].value === value) {
|
2018-08-16 22:30:59 +00:00
|
|
|
return
|
|
|
|
}
|
|
|
|
|
|
|
|
if (this[s].has(value)) {
|
|
|
|
const entry = this[s].get(value)
|
|
|
|
if (entry.prev) {
|
|
|
|
entry.prev.next = entry.next
|
|
|
|
}
|
|
|
|
if (entry.next) {
|
|
|
|
entry.next.prev = entry.prev
|
|
|
|
}
|
|
|
|
}
|
|
|
|
const obj = { value, next: this[start], prev: undefined }
|
|
|
|
this[start] = obj
|
|
|
|
if (this[start].next) {
|
|
|
|
this[start].next.prev = obj
|
|
|
|
}
|
|
|
|
this[s].set(value, obj)
|
|
|
|
}
|
|
|
|
|
2020-11-01 16:41:19 +00:00
|
|
|
*[Symbol.iterator]() {
|
2018-08-16 22:30:59 +00:00
|
|
|
let current = this[start]
|
|
|
|
do {
|
|
|
|
yield current.value
|
2020-11-01 16:41:19 +00:00
|
|
|
} while ((current = current.next))
|
2018-08-16 22:30:59 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
return LRU
|
2020-11-01 16:41:19 +00:00
|
|
|
})
|