Skip to content

Commit

Permalink
perf(merge): avoid arrow function in loop and avoid calling user-prov…
Browse files Browse the repository at this point in the history
…ided key generator more than once per item (#60)

Co-authored-by: Vladimir Ivakin <[email protected]>
  • Loading branch information
aleclarson and Minhir authored Jul 2, 2024
1 parent 20daf2a commit 1437d19
Showing 1 changed file with 14 additions and 18 deletions.
32 changes: 14 additions & 18 deletions src/array/merge.ts
Original file line number Diff line number Diff line change
Expand Up @@ -13,29 +13,25 @@
* ```
*/
export function merge<T>(
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
}, [] as T[])
const keys = array.map(toKey)
return prev.map((prevItem) => {
const index = keys.indexOf(toKey(prevItem));
return index > -1 ? array[index] : prevItem;
})
}

0 comments on commit 1437d19

Please sign in to comment.