Skip to content

Commit

Permalink
prefer epoch number comparisons to indicate value change (#2828)
Browse files Browse the repository at this point in the history
  • Loading branch information
dmaskasky authored Nov 18, 2024
1 parent 474e369 commit 14c028a
Showing 1 changed file with 4 additions and 6 deletions.
10 changes: 4 additions & 6 deletions src/vanilla/store.ts
Original file line number Diff line number Diff line change
Expand Up @@ -538,12 +538,11 @@ const buildStore = (
// NOTE technically possible but restricted as it may cause bugs
throw new Error('atom not writable')
}
const hasPrevValue = 'v' in aState
const prevValue = aState.v
const prevEpochNumber = aState.n
const v = args[0] as V
setAtomStateValueOrPromise(a, aState, v)
mountDependencies(pending, a, aState)
if (!hasPrevValue || !Object.is(prevValue, aState.v)) {
if (prevEpochNumber !== aState.n) {
addPendingAtom(pending, a, aState)
recomputeDependents(pending, a, aState)
}
Expand Down Expand Up @@ -726,11 +725,10 @@ const buildStore = (
for (const [atom, value] of values) {
if (hasInitialValue(atom)) {
const atomState = getAtomState(atom)
const hasPrevValue = 'v' in atomState
const prevValue = atomState.v
const prevEpochNumber = atomState.n
setAtomStateValueOrPromise(atom, atomState, value)
mountDependencies(pending, atom, atomState)
if (!hasPrevValue || !Object.is(prevValue, atomState.v)) {
if (prevEpochNumber !== atomState.n) {
addPendingAtom(pending, atom, atomState)
recomputeDependents(pending, atom, atomState)
}
Expand Down

0 comments on commit 14c028a

Please sign in to comment.