|
|
@ -29,13 +29,13 @@ import {
|
|
|
|
ROOT_EFFECT,
|
|
|
|
ROOT_EFFECT,
|
|
|
|
LEGACY_DERIVED_PROP,
|
|
|
|
LEGACY_DERIVED_PROP,
|
|
|
|
DISCONNECTED,
|
|
|
|
DISCONNECTED,
|
|
|
|
STATE_FROZEN_SYMBOL
|
|
|
|
STATE_FROZEN_SYMBOL,
|
|
|
|
|
|
|
|
INSPECT_EFFECT
|
|
|
|
} from './constants.js';
|
|
|
|
} from './constants.js';
|
|
|
|
import { flush_tasks } from './dom/task.js';
|
|
|
|
import { flush_tasks } from './dom/task.js';
|
|
|
|
import { add_owner } from './dev/ownership.js';
|
|
|
|
import { add_owner } from './dev/ownership.js';
|
|
|
|
import { mutate, set, source } from './reactivity/sources.js';
|
|
|
|
import { mutate, set, source } from './reactivity/sources.js';
|
|
|
|
import { update_derived } from './reactivity/deriveds.js';
|
|
|
|
import { update_derived } from './reactivity/deriveds.js';
|
|
|
|
import { inspect_captured_signals, inspect_fn, set_inspect_fn } from './dev/inspect.js';
|
|
|
|
|
|
|
|
import * as e from './errors.js';
|
|
|
|
import * as e from './errors.js';
|
|
|
|
import { lifecycle_outside_component } from '../shared/errors.js';
|
|
|
|
import { lifecycle_outside_component } from '../shared/errors.js';
|
|
|
|
|
|
|
|
|
|
|
@ -63,9 +63,7 @@ export function set_is_destroying_effect(value) {
|
|
|
|
is_destroying_effect = value;
|
|
|
|
is_destroying_effect = value;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
// Used for $inspect
|
|
|
|
export let inspect_effects = new Set();
|
|
|
|
export let is_batching_effect = false;
|
|
|
|
|
|
|
|
let is_inspecting_signal = false;
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
// Handle effect queues
|
|
|
|
// Handle effect queues
|
|
|
|
|
|
|
|
|
|
|
@ -159,38 +157,6 @@ export function is_runes() {
|
|
|
|
return current_component_context !== null && current_component_context.l === null;
|
|
|
|
return current_component_context !== null && current_component_context.l === null;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
|
|
|
* @param {import('#client').ProxyStateObject} target
|
|
|
|
|
|
|
|
* @param {string | symbol} prop
|
|
|
|
|
|
|
|
* @param {any} receiver
|
|
|
|
|
|
|
|
*/
|
|
|
|
|
|
|
|
export function batch_inspect(target, prop, receiver) {
|
|
|
|
|
|
|
|
const value = Reflect.get(target, prop, receiver);
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
|
|
|
* @this {any}
|
|
|
|
|
|
|
|
*/
|
|
|
|
|
|
|
|
return function () {
|
|
|
|
|
|
|
|
const previously_batching_effect = is_batching_effect;
|
|
|
|
|
|
|
|
is_batching_effect = true;
|
|
|
|
|
|
|
|
try {
|
|
|
|
|
|
|
|
return Reflect.apply(value, this, arguments);
|
|
|
|
|
|
|
|
} finally {
|
|
|
|
|
|
|
|
is_batching_effect = previously_batching_effect;
|
|
|
|
|
|
|
|
if (last_inspected_signal !== null && !is_inspecting_signal) {
|
|
|
|
|
|
|
|
is_inspecting_signal = true;
|
|
|
|
|
|
|
|
try {
|
|
|
|
|
|
|
|
for (const fn of last_inspected_signal.inspect) {
|
|
|
|
|
|
|
|
fn();
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
} finally {
|
|
|
|
|
|
|
|
is_inspecting_signal = false;
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
last_inspected_signal = null;
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
};
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
/**
|
|
|
|
* Determines whether a derived or effect is dirty.
|
|
|
|
* Determines whether a derived or effect is dirty.
|
|
|
|
* If it is MAYBE_DIRTY, will set the status to CLEAN
|
|
|
|
* If it is MAYBE_DIRTY, will set the status to CLEAN
|
|
|
@ -793,12 +759,6 @@ export async function tick() {
|
|
|
|
* @returns {V}
|
|
|
|
* @returns {V}
|
|
|
|
*/
|
|
|
|
*/
|
|
|
|
export function get(signal) {
|
|
|
|
export function get(signal) {
|
|
|
|
if (DEV && inspect_fn) {
|
|
|
|
|
|
|
|
var s = /** @type {import('#client').ValueDebug} */ (signal);
|
|
|
|
|
|
|
|
s.inspect.add(inspect_fn);
|
|
|
|
|
|
|
|
inspect_captured_signals.push(s);
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
const flags = signal.f;
|
|
|
|
const flags = signal.f;
|
|
|
|
if ((flags & DESTROYED) !== 0) {
|
|
|
|
if ((flags & DESTROYED) !== 0) {
|
|
|
|
return signal.v;
|
|
|
|
return signal.v;
|
|
|
@ -846,15 +806,7 @@ export function get(signal) {
|
|
|
|
(flags & DERIVED) !== 0 &&
|
|
|
|
(flags & DERIVED) !== 0 &&
|
|
|
|
check_dirtiness(/** @type {import('#client').Derived} */ (signal))
|
|
|
|
check_dirtiness(/** @type {import('#client').Derived} */ (signal))
|
|
|
|
) {
|
|
|
|
) {
|
|
|
|
if (DEV) {
|
|
|
|
update_derived(/** @type {import('#client').Derived} **/ (signal), false);
|
|
|
|
// we want to avoid tracking indirect dependencies
|
|
|
|
|
|
|
|
const previous_inspect_fn = inspect_fn;
|
|
|
|
|
|
|
|
set_inspect_fn(null);
|
|
|
|
|
|
|
|
update_derived(/** @type {import('#client').Derived} **/ (signal), false);
|
|
|
|
|
|
|
|
set_inspect_fn(previous_inspect_fn);
|
|
|
|
|
|
|
|
} else {
|
|
|
|
|
|
|
|
update_derived(/** @type {import('#client').Derived} **/ (signal), false);
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
return signal.v;
|
|
|
|
return signal.v;
|
|
|
@ -914,6 +866,11 @@ export function mark_reactions(signal, to_status, force_schedule) {
|
|
|
|
var reaction = reactions[i];
|
|
|
|
var reaction = reactions[i];
|
|
|
|
var flags = reaction.f;
|
|
|
|
var flags = reaction.f;
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
if (DEV && (flags & INSPECT_EFFECT) !== 0) {
|
|
|
|
|
|
|
|
inspect_effects.add(reaction);
|
|
|
|
|
|
|
|
continue;
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
// We skip any effects that are already dirty. Additionally, we also
|
|
|
|
// We skip any effects that are already dirty. Additionally, we also
|
|
|
|
// skip if the reaction is the same as the current effect (except if we're not in runes or we
|
|
|
|
// skip if the reaction is the same as the current effect (except if we're not in runes or we
|
|
|
|
// are in force schedule mode).
|
|
|
|
// are in force schedule mode).
|
|
|
|