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.
33 lines
626 B
33 lines
626 B
1 month ago
|
/*
|
||
|
MIT License http://www.opensource.org/licenses/mit-license.php
|
||
|
*/
|
||
|
|
||
|
"use strict";
|
||
|
|
||
|
/** @template T @typedef {function(): T} FunctionReturning */
|
||
|
|
||
|
/**
|
||
|
* @template T
|
||
|
* @param {FunctionReturning<T>} fn memorized function
|
||
|
* @returns {FunctionReturning<T>} new function
|
||
|
*/
|
||
|
const memoize = fn => {
|
||
|
let cache = false;
|
||
|
/** @type {T | undefined} */
|
||
|
let result;
|
||
|
return () => {
|
||
|
if (cache) {
|
||
|
return /** @type {T} */ (result);
|
||
|
}
|
||
|
|
||
|
result = fn();
|
||
|
cache = true;
|
||
|
// Allow to clean up memory for fn
|
||
|
// and all dependent resources
|
||
|
fn = undefined;
|
||
|
return /** @type {T} */ (result);
|
||
|
};
|
||
|
};
|
||
|
|
||
|
module.exports = memoize;
|