Skip to content

Commit

Permalink
Merge pull request Expensify#50231 from callstack-internal/chore/memo…
Browse files Browse the repository at this point in the history
…ize-module-descriptions

[NoQA] Chore: Memoize module description update
  • Loading branch information
mountiny authored Oct 4, 2024
2 parents 5b6886a + 120bdc9 commit 3c91e07
Show file tree
Hide file tree
Showing 2 changed files with 39 additions and 5 deletions.
15 changes: 15 additions & 0 deletions src/libs/memoize/stats.ts
Original file line number Diff line number Diff line change
Expand Up @@ -13,14 +13,29 @@ function isMemoizeStatsEntry(entry: any): entry is MemoizeStatsEntry {
}

class MemoizeStats {
/**
* Number of calls to the memoized function. Both cache hits and misses are counted.
*/
private calls = 0;

/**
* Number of cache hits. This is the number of times the cache returned a value instead of calling the original function.
*/
private hits = 0;

/**
* Average time of cache retrieval. This is the time it takes to retrieve a value from the cache, without calling the original function.
*/
private avgCacheTime = 0;

/**
* Average time of original function execution. This is the time it takes to execute the original function when the cache does not have a value.
*/
private avgFnTime = 0;

/**
* Current cache size. This is the number of entries in the cache.
*/
private cacheSize = 0;

isEnabled = false;
Expand Down
29 changes: 24 additions & 5 deletions src/libs/memoize/types.ts
Original file line number Diff line number Diff line change
Expand Up @@ -16,21 +16,40 @@ type IsomorphicReturnType<Fn extends IsomorphicFn> = Fn extends Callable ? Retur
type KeyComparator<Key> = (k1: Key, k2: Key) => boolean;

type InternalOptions = {
/**
* Type of cache to use. Currently only `array` is supported.
*/
cache: 'array';
};

type Options<Fn extends IsomorphicFn, MaxArgs extends number, Key> = {
/**
* Maximum number of entries in the cache. If the cache exceeds this number, the oldest entries will be removed.
*/
maxSize: number;
/**
* Equality comparator to use for comparing keys in the cache. Can be either:
* - `deep` - default comparator that uses [DeepEqual](https://github.com/planttheidea/fast-equals?tab=readme-ov-file#deepequal)
* - `shallow` - comparator that uses [ShallowEqual](https://github.com/planttheidea/fast-equals?tab=readme-ov-file#shallowequal)
* - a custom comparator - a function that takes two keys and returns a boolean.
*/
equality: 'deep' | 'shallow' | KeyComparator<Key>;
/**
* If set to `true`, memoized function stats will be collected. It can be overridden by global `Memoize` config. See `MemoizeStats` for more information.
*/
monitor: boolean;
/**
* Maximum number of arguments to use for caching. If set, only the first `maxArgs` arguments will be used to generate the cache key.
*/
maxArgs?: MaxArgs;
/**
* Name of the monitoring entry. If not provided, the function name will be used.
*/
monitoringName?: string;
/**
* Function to transform the arguments into a key, which is used to reference the result in the cache.
* When called with constructable (e.g. class, `new` keyword) functions, it won't get proper types for `truncatedArgs`
* Any viable fixes are welcome!
* @param truncatedArgs - Tuple of arguments passed to the memoized function (truncated to `maxArgs`). Does not work with constructable (see description).
* @returns - Key to use for caching
* Transforms arguments into a cache key. If set, `maxArgs` will be applied to arguments first.
* @param truncatedArgs Tuple of arguments passed to the memoized function (truncated to `maxArgs`). Does not work with constructable (see description).
* @returns Key to use for caching
*/
transformKey?: (truncatedArgs: TakeFirst<IsomorphicParameters<Fn>, MaxArgs>) => Key;
} & InternalOptions;
Expand Down

0 comments on commit 3c91e07

Please sign in to comment.