pull/12073/head
Rich Harris 7 months ago
parent b41f18007d
commit a444746111

@ -5,7 +5,6 @@ export const BLOCK_EFFECT = 1 << 4;
export const BRANCH_EFFECT = 1 << 5; export const BRANCH_EFFECT = 1 << 5;
export const ROOT_EFFECT = 1 << 6; export const ROOT_EFFECT = 1 << 6;
export const UNOWNED = 1 << 7; export const UNOWNED = 1 << 7;
export const DISCONNECTED = 1 << 8;
export const CLEAN = 1 << 9; export const CLEAN = 1 << 9;
export const DIRTY = 1 << 10; export const DIRTY = 1 << 10;
export const MAYBE_DIRTY = 1 << 11; export const MAYBE_DIRTY = 1 << 11;

@ -28,7 +28,6 @@ import {
BLOCK_EFFECT, BLOCK_EFFECT,
ROOT_EFFECT, ROOT_EFFECT,
LEGACY_DERIVED_PROP, LEGACY_DERIVED_PROP,
DISCONNECTED,
STATE_FROZEN_SYMBOL, STATE_FROZEN_SYMBOL,
INSPECT_EFFECT INSPECT_EFFECT
} from './constants.js'; } from './constants.js';
@ -157,14 +156,11 @@ export function is_runes() {
*/ */
export function check_dirtiness(reaction) { export function check_dirtiness(reaction) {
var flags = reaction.f; var flags = reaction.f;
var is_dirty = (flags & DIRTY) !== 0;
if (is_dirty) { var is_dirty = (flags & DIRTY) !== 0;
return true; if (is_dirty) return true;
}
var is_unowned = (flags & UNOWNED) !== 0; var is_derived = (flags & DERIVED) !== 0;
var is_disconnected = (flags & DISCONNECTED) !== 0;
if ((flags & MAYBE_DIRTY) !== 0) { if ((flags & MAYBE_DIRTY) !== 0) {
var dependencies = reaction.deps; var dependencies = reaction.deps;
@ -179,7 +175,7 @@ export function check_dirtiness(reaction) {
update_derived(/** @type {import('#client').Derived} **/ (dependency), true); update_derived(/** @type {import('#client').Derived} **/ (dependency), true);
} }
if (is_unowned || is_disconnected) { if (is_derived) {
// TODO why is this happening here rather than in `update_derived`? // TODO why is this happening here rather than in `update_derived`?
if (!dependency.reactions?.includes(reaction)) { if (!dependency.reactions?.includes(reaction)) {
(dependency.reactions ??= []).push(reaction); (dependency.reactions ??= []).push(reaction);
@ -196,13 +192,9 @@ export function check_dirtiness(reaction) {
} }
// Unowned signals are always maybe dirty, as we instead check their dependency versions. // Unowned signals are always maybe dirty, as we instead check their dependency versions.
if (!is_unowned) { if ((flags & UNOWNED) === 0) {
set_signal_status(reaction, CLEAN); set_signal_status(reaction, CLEAN);
} }
if (is_disconnected) {
reaction.f ^= DISCONNECTED;
}
} }
return is_dirty; return is_dirty;
@ -384,11 +376,6 @@ function remove_reaction(signal, dependency) {
// allowing it to either reconnect in the future, or be GC'd by the VM. // allowing it to either reconnect in the future, or be GC'd by the VM.
if (reactions_length === 0 && (dependency.f & DERIVED) !== 0) { if (reactions_length === 0 && (dependency.f & DERIVED) !== 0) {
set_signal_status(dependency, MAYBE_DIRTY); set_signal_status(dependency, MAYBE_DIRTY);
// If we are working with a derived that is owned by an effect, then mark it as being
// disconnected.
if ((dependency.f & (UNOWNED | DISCONNECTED)) === 0) {
dependency.f ^= DISCONNECTED;
}
remove_reactions(/** @type {import('#client').Derived} **/ (dependency), 0); remove_reactions(/** @type {import('#client').Derived} **/ (dependency), 0);
} }
} }

Loading…
Cancel
Save