Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/avoidwork/tiny-lru
Tiny LRU cache for Client or Server
https://github.com/avoidwork/tiny-lru
Last synced: 4 days ago
JSON representation
Tiny LRU cache for Client or Server
- Host: GitHub
- URL: https://github.com/avoidwork/tiny-lru
- Owner: avoidwork
- License: bsd-3-clause
- Created: 2013-07-26T11:14:15.000Z (over 11 years ago)
- Default Branch: master
- Last Pushed: 2025-01-13T06:28:12.000Z (15 days ago)
- Last Synced: 2025-01-17T00:06:55.316Z (11 days ago)
- Language: JavaScript
- Homepage:
- Size: 1.36 MB
- Stars: 159
- Watchers: 3
- Forks: 25
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- Changelog: CHANGELOG.md
- Funding: .github/FUNDING.yml
- License: LICENSE
Awesome Lists containing this project
- awesome-javascript - tiny-lru
- awesome-javascript - tiny-lru
README
# Tiny LRU
Least Recently Used cache for Client or Server.
## Using the factory
```javascript
import {lru} from "tiny-lru";
const cache = lru(max, ttl = 0, resetTtl = false);
```## Using the Class
```javascript
import {LRU} from "tiny-lru";
const cache = new LRU(max, ttl = 0, resetTtl = false);
``````javascript
import {LRU} from "tiny-lru";
class MyCache extends LRU {}
```## Interoperability
Lodash provides a `memoize` function with a cache that can be swapped out as long as it implements the right interface.
See the [lodash docs](https://lodash.com/docs#memoize) for more on `memoize`.### Example
```javascript
_.memoize.Cache = lru().constructor;
const memoized = _.memoize(myFunc);
memoized.cache.max = 10;
```## Testing
Tiny-LRU has 100% code coverage with its tests.
```console
--------------|---------|----------|---------|---------|-------------------
File | % Stmts | % Branch | % Funcs | % Lines | Uncovered Line #s
--------------|---------|----------|---------|---------|-------------------
All files | 100 | 91.54 | 100 | 100 |
tiny-lru.cjs | 100 | 91.54 | 100 | 100 | 11-31,150,184
--------------|---------|----------|---------|---------|-------------------
```## API
## Properties
### first
Item in "first" or "bottom" position; default is `null`
**Example**
```javascript
const cache = lru();cache.first; // null - it's a new cache!
```### last
Item in "last" or "top" position; default is `null`
**Example**
```javascript
const cache = lru();cache.last; // null - it's a new cache!
```### max
Max items to hold in cache; default is `1000`
**Example**
```javascript
const cache = lru(500);cache.max; // 500
```### resetTtl
Resets `item.expiry` with each `set()` if `true`; default is `false`
**Example**
```javascript
const cache = lru(500, 5*6e4, true);cache.resetTtl; // true
```### size
Number of items in cache
**Example**
```javascript
const cache = lru();cache.size; // 0 - it's a new cache!
```### ttl
Milliseconds an item will remain in cache; lazy expiration upon next `get()` of an item
**Example**
```javascript
const cache = lru(100, 3e4);cache.ttl; // 30000;
```## Methods
### clear
Clears the contents of the cache
return {Object} LRU instance
**Example**
```javascript
cache.clear();
```### delete
Removes item from cache
param {String} key Item key
return {Object} LRU instance**Example**
```javascript
cache.delete("myKey");
```### entries(*["key1", "key2"]*)
Returns an `Array` cache items
param {Array} keys (Optional) Cache item keys to get, defaults to `this.keys()` if not provided
return {Object} LRU instance**Example**
```javascript
cache.entries(['myKey1', 'myKey2']);
```### evict
Evicts the least recently used item from cache
return {Object} LRU instance
**Example**
```javascript
cache.evict();
```### expiresAt
Gets expiration time for cached item
param {String} key Item key
return {Mixed} Undefined or number (epoch time)**Example**
```javascript
const item = cache.expiresAt("myKey");
```### get
Gets cached item and moves it to the front
param {String} key Item key
return {Mixed} Undefined or Item value**Example**
```javascript
const item = cache.get("myKey");
```### has
Returns a `Boolean` indicating if `key` is in cache
return {Object} LRU instance
**Example**
```javascript
cache.has('myKey');
```### keys
Returns an `Array` of cache item keys (`first` to `last`)
return {Array} Array of keys
**Example**
```javascript
console.log(cache.keys());
```### set
Sets item in cache as `first`
param {String} key Item key
param {Mixed} value Item value
return {Object} LRU instance**Example**
```javascript
cache.set("myKey", {prop: true});
```### values(*["key1", "key2"]*)
Returns an `Array` cache items
param {Array} keys (Optional) Cache item keys to get
return {Array} Cache items**Example**
```javascript
cache.values(['abc', 'def']);
```## License
Copyright (c) 2024 Jason Mulligan
Licensed under the BSD-3 license.