From 70358d9d8dc1759f011851a110225bcdb3986122 Mon Sep 17 00:00:00 2001 From: Alec Larson <1925840+aleclarson@users.noreply.github.com> Date: Tue, 2 Jul 2024 12:56:11 -0400 Subject: [PATCH] perf(merge): avoid arrow function in loop and avoid calling user-provided key generator more than once per item --- src/array/merge.ts | 31 ++++++++++++++----------------- 1 file changed, 14 insertions(+), 17 deletions(-) diff --git a/src/array/merge.ts b/src/array/merge.ts index 09f35393..2cb6cd6b 100644 --- a/src/array/merge.ts +++ b/src/array/merge.ts @@ -13,29 +13,26 @@ * ``` */ export function merge( - root: readonly T[], - others: readonly T[], - matcher: (item: T) => any, + prev: readonly T[], + array: readonly T[], + toKey: (item: T) => any, ): T[] { - if (!others && !root) { + if (!array && !prev) { return [] } - if (!others) { - return [...root] + if (!array) { + return [...prev] } - if (!root) { + if (!prev) { return [] } - if (!matcher) { - return [...root] + if (!toKey) { + return [...prev] } - return root.reduce((acc, r) => { - const matched = others.find(o => matcher(r) === matcher(o)) - if (matched) { - acc.push(matched) - } else { - acc.push(r) - } - return acc + const keys = array.map(toKey) + return prev.reduce((next, prevItem) => { + const index = keys.indexOf(toKey(prevItem)) + next.push(index > -1 ? array[index] : prevItem) + return next }, [] as T[]) }