simplify, make non-recursive

pull/15348/head
Rich Harris 7 months ago
parent 75f0adf3ae
commit a2e3fb90e2

@ -615,8 +615,6 @@ function log_effect_stack() {
} }
function infinite_loop_guard() { function infinite_loop_guard() {
if (flush_count > 1000) {
flush_count = 0;
try { try {
e.effect_update_depth_exceeded(); e.effect_update_depth_exceeded();
} catch (error) { } catch (error) {
@ -647,8 +645,6 @@ function infinite_loop_guard() {
throw error; throw error;
} }
} }
}
flush_count++;
} }
/** /**
@ -656,20 +652,24 @@ function infinite_loop_guard() {
* @returns {void} * @returns {void}
*/ */
function flush_queued_root_effects(root_effects) { function flush_queued_root_effects(root_effects) {
queued_root_effects = [];
var length = root_effects.length;
if (length === 0) {
return;
}
infinite_loop_guard();
var previously_flushing_effect = is_flushing_effect; var previously_flushing_effect = is_flushing_effect;
is_flushing_effect = true; is_flushing_effect = true;
is_flushing = true; is_flushing = true;
try { try {
var length = queued_root_effects.length;
var flush_count = 0;
while (queued_root_effects.length > 0) {
if (flush_count++ > 1000) {
infinite_loop_guard();
}
var root_effects = queued_root_effects;
var length = root_effects.length;
queued_root_effects = [];
for (var i = 0; i < length; i++) { for (var i = 0; i < length; i++) {
var effect = root_effects[i]; var effect = root_effects[i];
@ -680,9 +680,6 @@ function flush_queued_root_effects(root_effects) {
var collected_effects = process_effects(effect); var collected_effects = process_effects(effect);
flush_queued_effects(collected_effects); flush_queued_effects(collected_effects);
} }
if (queued_root_effects.length > 0) {
flush_queued_root_effects(queued_root_effects);
} }
} finally { } finally {
is_flushing_effect = previously_flushing_effect; is_flushing_effect = previously_flushing_effect;
@ -851,8 +848,6 @@ function process_effects(effect) {
* @returns {any} * @returns {any}
*/ */
export function flush_sync(fn) { export function flush_sync(fn) {
infinite_loop_guard();
is_micro_task_queued = false; is_micro_task_queued = false;
flush_queued_root_effects(queued_root_effects); flush_queued_root_effects(queued_root_effects);

Loading…
Cancel
Save