viem
Version:
34 lines (28 loc) • 718 B
text/typescript
/**
* Map with a LRU (Least recently used) policy.
*
* @link https://en.wikipedia.org/wiki/Cache_replacement_policies#LRU
*/
export class LruMap<value = unknown> extends Map<string, value> {
maxSize: number
constructor(size: number) {
super()
this.maxSize = size
}
override get(key: string) {
const value = super.get(key)
if (super.has(key) && value !== undefined) {
this.delete(key)
super.set(key, value)
}
return value
}
override set(key: string, value: value) {
super.set(key, value)
if (this.maxSize && this.size > this.maxSize) {
const firstKey = this.keys().next().value
if (firstKey) this.delete(firstKey)
}
return this
}
}