chore: ensure effect destruction of deriveds is consistent (#13693)

* chore: ensure effect destruction of deriveds is consistent

* chore: ensure effect destruction of deriveds is consistent
pull/13695/head
Dominic Gannaway 3 months ago committed by GitHub
parent bb491f1229
commit a577ce08c6
No known key found for this signature in database
GPG Key ID: B5690EEEBB952194

@ -4,7 +4,6 @@ import {
component_context, component_context,
active_effect, active_effect,
active_reaction, active_reaction,
destroy_effect_children,
dev_current_component_function, dev_current_component_function,
update_effect, update_effect,
get, get,
@ -43,6 +42,7 @@ import * as e from '../errors.js';
import { DEV } from 'esm-env'; import { DEV } from 'esm-env';
import { define_property } from '../../shared/utils.js'; import { define_property } from '../../shared/utils.js';
import { get_next_sibling } from '../dom/operations.js'; import { get_next_sibling } from '../dom/operations.js';
import { destroy_derived } from './deriveds.js';
/** /**
* @param {'$effect' | '$effect.pre' | '$inspect'} rune * @param {'$effect' | '$effect.pre' | '$inspect'} rune
@ -364,6 +364,54 @@ export function execute_effect_teardown(effect) {
} }
} }
/**
* @param {Effect} signal
* @returns {void}
*/
export function destroy_effect_deriveds(signal) {
var deriveds = signal.deriveds;
if (deriveds !== null) {
signal.deriveds = null;
for (var i = 0; i < deriveds.length; i += 1) {
destroy_derived(deriveds[i]);
}
}
}
/**
* @param {Effect} signal
* @param {boolean} remove_dom
* @returns {void}
*/
export function destroy_effect_children(signal, remove_dom = false) {
var effect = signal.first;
signal.first = signal.last = null;
while (effect !== null) {
var next = effect.next;
destroy_effect(effect, remove_dom);
effect = next;
}
}
/**
* @param {Effect} signal
* @returns {void}
*/
export function destroy_block_effect_children(signal) {
var effect = signal.first;
while (effect !== null) {
var next = effect.next;
if ((effect.f & BRANCH_EFFECT) === 0) {
destroy_effect(effect);
}
effect = next;
}
}
/** /**
* @param {Effect} effect * @param {Effect} effect
* @param {boolean} [remove_dom] * @param {boolean} [remove_dom]
@ -401,6 +449,7 @@ export function destroy_effect(effect, remove_dom = true) {
removed = true; removed = true;
} }
destroy_effect_deriveds(effect);
destroy_effect_children(effect, remove_dom && !removed); destroy_effect_children(effect, remove_dom && !removed);
remove_reactions(effect, 0); remove_reactions(effect, 0);
set_signal_status(effect, DESTROYED); set_signal_status(effect, DESTROYED);

@ -2,7 +2,9 @@
import { DEV } from 'esm-env'; import { DEV } from 'esm-env';
import { define_property, get_descriptors, get_prototype_of } from '../shared/utils.js'; import { define_property, get_descriptors, get_prototype_of } from '../shared/utils.js';
import { import {
destroy_effect, destroy_block_effect_children,
destroy_effect_children,
destroy_effect_deriveds,
effect, effect,
execute_effect_teardown, execute_effect_teardown,
unlink_effect unlink_effect
@ -403,48 +405,6 @@ export function remove_reactions(signal, start_index) {
} }
} }
/**
* @param {Effect} signal
* @param {boolean} remove_dom
* @returns {void}
*/
export function destroy_effect_children(signal, remove_dom = false) {
var deriveds = signal.deriveds;
if (deriveds !== null) {
signal.deriveds = null;
for (var i = 0; i < deriveds.length; i += 1) {
destroy_derived(deriveds[i]);
}
}
var effect = signal.first;
signal.first = signal.last = null;
while (effect !== null) {
var next = effect.next;
destroy_effect(effect, remove_dom);
effect = next;
}
}
/**
* @param {Effect} signal
* @returns {void}
*/
export function destroy_block_effect_children(signal) {
var effect = signal.first;
while (effect !== null) {
var next = effect.next;
if ((effect.f & BRANCH_EFFECT) === 0) {
destroy_effect(effect);
}
effect = next;
}
}
/** /**
* @param {Effect} effect * @param {Effect} effect
* @returns {void} * @returns {void}
@ -470,6 +430,7 @@ export function update_effect(effect) {
} }
try { try {
destroy_effect_deriveds(effect);
if ((flags & BLOCK_EFFECT) !== 0) { if ((flags & BLOCK_EFFECT) !== 0) {
destroy_block_effect_children(effect); destroy_block_effect_children(effect);
} else { } else {

Loading…
Cancel
Save