You can not select more than 25 topics
			Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
		
		
		
		
		
			
		
			
				
					44 lines
				
				1.2 KiB
			
		
		
			
		
	
	
					44 lines
				
				1.2 KiB
			| 
											3 years ago
										 | /** | ||
|  |  * Mnemonist LRUCache Typings | ||
|  |  * =========================== | ||
|  |  */ | ||
|  | import {IArrayLikeConstructor} from './utils/types'; | ||
|  | 
 | ||
|  | export default class LRUCache<K, V> implements Iterable<[K, V]> { | ||
|  | 
 | ||
|  |   // Members
 | ||
|  |   capacity: number; | ||
|  |   size: number; | ||
|  | 
 | ||
|  |   // Constructor
 | ||
|  |   constructor(capacity: number); | ||
|  |   constructor(KeyArrayClass: IArrayLikeConstructor, ValueArrayClass: IArrayLikeConstructor, capacity: number); | ||
|  | 
 | ||
|  |   // Methods
 | ||
|  |   clear(): void; | ||
|  |   set(key: K, value: V): this; | ||
|  |   setpop(key: K, value: V): {evicted: boolean, key: K, value: V}; | ||
|  |   get(key: K): V | undefined; | ||
|  |   peek(key: K): V | undefined; | ||
|  |   has(key: K): boolean; | ||
|  |   forEach(callback: (value: V, key: K, cache: this) => void, scope?: any): void; | ||
|  |   keys(): IterableIterator<K>; | ||
|  |   values(): IterableIterator<V>; | ||
|  |   entries(): IterableIterator<[K, V]>; | ||
|  |   [Symbol.iterator](): IterableIterator<[K, V]>; | ||
|  |   inspect(): any; | ||
|  | 
 | ||
|  |   // Statics
 | ||
|  |   static from<I, J>( | ||
|  |     iterable: Iterable<[I, J]> | {[key: string]: J}, | ||
|  |     KeyArrayClass: IArrayLikeConstructor, | ||
|  |     ValueArrayClass: IArrayLikeConstructor, | ||
|  |     capacity?: number | ||
|  |   ): LRUCache<I, J>; | ||
|  | 
 | ||
|  |   static from<I, J>( | ||
|  |     iterable: Iterable<[I, J]> | {[key: string]: J}, | ||
|  |     capacity?: number | ||
|  |   ): LRUCache<I, J>; | ||
|  | } |