- Complete React app with 7 developer tools - JSON Tool with visual structured editor - Serialize Tool with visual structured editor - URL, Base64, CSV/JSON, Beautifier, Diff tools - Responsive navigation with dropdown menu - Dark/light mode toggle - Mobile-responsive design with sticky header - All tools working with copy/paste functionality
37 lines
681 B
JavaScript
37 lines
681 B
JavaScript
/*
|
|
MIT License http://www.opensource.org/licenses/mit-license.php
|
|
*/
|
|
|
|
"use strict";
|
|
|
|
/**
|
|
* @template T
|
|
* @typedef {() => 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
|
|
/** @type {FunctionReturning<T> | undefined} */
|
|
(fn) = undefined;
|
|
return /** @type {T} */ (result);
|
|
};
|
|
};
|
|
|
|
module.exports = memoize;
|