From 620f78c74e66bc532a96e28b26fd2d0ed1b67d54 Mon Sep 17 00:00:00 2001 From: Julien Barrois Date: Wed, 10 Jan 2024 09:03:08 +0100 Subject: [PATCH] Prevent Reaction From Keeping a Reference to The OldValue (#3812) --- .changeset/six-pugs-impress.md | 5 +++++ packages/mobx/src/api/autorun.ts | 3 +-- 2 files changed, 6 insertions(+), 2 deletions(-) create mode 100644 .changeset/six-pugs-impress.md diff --git a/.changeset/six-pugs-impress.md b/.changeset/six-pugs-impress.md new file mode 100644 index 000000000..0003e6852 --- /dev/null +++ b/.changeset/six-pugs-impress.md @@ -0,0 +1,5 @@ +--- +"mobx": patch +--- + +Prevent `reaction` from heeping a Reference to the OldValue that would prevent GC. diff --git a/packages/mobx/src/api/autorun.ts b/packages/mobx/src/api/autorun.ts index ddf96ed3f..4843ad789 100644 --- a/packages/mobx/src/api/autorun.ts +++ b/packages/mobx/src/api/autorun.ts @@ -139,7 +139,6 @@ export function reaction( let firstTime = true let isScheduled = false let value: T - let oldValue: T | undefined const equals: IEqualsComparer = (opts as any).compareStructural ? comparer.structural @@ -165,10 +164,10 @@ export function reaction( return } let changed: boolean = false + const oldValue = value r.track(() => { const nextValue = allowStateChanges(false, () => expression(r)) changed = firstTime || !equals(value, nextValue) - oldValue = value value = nextValue })