UNPKG

github-release-info-downloader

Version:

Gets latest release download URL using the GitHub Releases API. It also shows when it was released and the download count.

60 lines (54 loc) 2.1 kB
// function utils /** * Memoize a given function by caching the computed result. * The cache of a memoized function can be cleared by deleting the `cache` * property of the function. * * @param {function} fn The function to be memoized. * Must be a pure function. * @param {function(args: Array)} [hasher] A custom hash builder. * Is JSON.stringify by default. * @return {function} Returns the memoized function */ exports.memoize = function(fn, hasher) { return function memoize() { if (typeof memoize.cache !== 'object') { memoize.cache = {}; } var args = []; for (var i = 0; i < arguments.length; i++) { args[i] = arguments[i]; } var hash = hasher ? hasher(args) : JSON.stringify(args); if (!(hash in memoize.cache)) { return memoize.cache[hash] = fn.apply(fn, args); } return memoize.cache[hash]; }; }; /** * Find the maximum number of arguments expected by a typed function. * @param {function} fn A typed function * @return {number} Returns the maximum number of expected arguments. * Returns -1 when no signatures where found on the function. */ exports.maxArgumentCount = function (fn) { return Object.keys(fn.signatures || {}) .reduce(function (args, signature) { var count = (signature.match(/,/g) || []).length + 1; return Math.max(args, count); }, -1); }; /** * Call a typed function with the * @param {function} fn A function or typed function * @return {number} Returns the maximum number of expected arguments. * Returns -1 when no signatures where found on the function. */ exports.callWithRightArgumentCount = function (fn, args, argCount) { return Object.keys(fn.signatures || {}) .reduce(function (args, signature) { var count = (signature.match(/,/g) || []).length + 1; return Math.max(args, count); }, -1); };