UNPKG

viem

Version:

TypeScript Interface for Ethereum

34 lines (28 loc) 718 B
/** * 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 } }