1
0
mirror of https://github.com/wbbaddons/Tims-Chat.git synced 2024-12-26 22:20:08 +00:00
Tims-Chat/files_wcf/js/Bastelstu.be/Chat/DataStructure/LRU.js

58 lines
1.1 KiB
JavaScript
Raw Normal View History

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.
*
2023-02-22 16:45:50 +00:00
* Change Date: 2027-02-22
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
})