LabeledStatement() — svelte Function Reference
Architecture documentation for the LabeledStatement() function in LabeledStatement.js from the svelte codebase.
Entity Profile
Dependency Diagram
graph TD 038a2b50_977f_79aa_8faf_2d5f9950a6ac["LabeledStatement()"] 5d572700_84fa_a20f_b641_c5b7becd2684["LabeledStatement.js"] 038a2b50_977f_79aa_8faf_2d5f9950a6ac -->|defined in| 5d572700_84fa_a20f_b641_c5b7becd2684 887995f5_7128_d841_eeb8_a6be1d0e0d05["legacy_reactive_statement_invalid()"] 038a2b50_977f_79aa_8faf_2d5f9950a6ac -->|calls| 887995f5_7128_d841_eeb8_a6be1d0e0d05 c12e0147_3f27_cf17_5878_e54ffdc328d5["extract_identifiers()"] 038a2b50_977f_79aa_8faf_2d5f9950a6ac -->|calls| c12e0147_3f27_cf17_5878_e54ffdc328d5 804afe56_25d1_9f41_dafe_adc75e952134["object()"] 038a2b50_977f_79aa_8faf_2d5f9950a6ac -->|calls| 804afe56_25d1_9f41_dafe_adc75e952134 690fff67_1638_45a4_757e_498d86739b15["reactive_declaration_invalid_placement()"] 038a2b50_977f_79aa_8faf_2d5f9950a6ac -->|calls| 690fff67_1638_45a4_757e_498d86739b15 style 038a2b50_977f_79aa_8faf_2d5f9950a6ac fill:#6366f1,stroke:#818cf8,color:#fff
Relationship Graph
Source Code
packages/svelte/src/compiler/phases/2-analyze/visitors/LabeledStatement.js lines 12–95
export function LabeledStatement(node, context) {
if (node.label.name === '$') {
const parent = /** @type {AST.SvelteNode} */ (context.path.at(-1));
const is_reactive_statement =
context.state.ast_type === 'instance' && parent.type === 'Program';
if (is_reactive_statement) {
if (context.state.analysis.runes) {
e.legacy_reactive_statement_invalid(node);
}
// Find all dependencies of this `$: {...}` statement
/** @type {ReactiveStatement} */
const reactive_statement = {
assignments: new Set(),
dependencies: []
};
context.next({
...context.state,
reactive_statement,
function_depth: context.state.scope.function_depth + 1
});
// Every referenced binding becomes a dependency, unless it's on
// the left-hand side of an `=` assignment
for (const [name, nodes] of context.state.scope.references) {
const binding = context.state.scope.get(name);
if (binding === null) continue;
for (const { node, path } of nodes) {
/** @type {Expression} */
let left = node;
let i = path.length - 1;
let parent = /** @type {Expression} */ (path.at(i));
while (parent.type === 'MemberExpression') {
left = parent;
parent = /** @type {Expression} */ (path.at(--i));
}
if (
parent.type === 'AssignmentExpression' &&
parent.operator === '=' &&
parent.left === left
) {
continue;
}
reactive_statement.dependencies.push(binding);
break;
}
}
context.state.analysis.reactive_statements.set(node, reactive_statement);
if (
node.body.type === 'ExpressionStatement' &&
node.body.expression.type === 'AssignmentExpression'
) {
let ids = extract_identifiers(node.body.expression.left);
if (node.body.expression.left.type === 'MemberExpression') {
const id = object(node.body.expression.left);
if (id !== null) {
ids = [id];
}
}
for (const id of ids) {
const binding = context.state.scope.get(id.name);
if (binding?.kind === 'legacy_reactive') {
// TODO does this include `let double; $: double = x * 2`?
binding.legacy_dependencies = Array.from(reactive_statement.dependencies);
}
}
}
} else if (!context.state.analysis.runes) {
w.reactive_declaration_invalid_placement(node);
}
}
Domain
Subdomains
Calls
Source
Frequently Asked Questions
What does LabeledStatement() do?
LabeledStatement() is a function in the svelte codebase, defined in packages/svelte/src/compiler/phases/2-analyze/visitors/LabeledStatement.js.
Where is LabeledStatement() defined?
LabeledStatement() is defined in packages/svelte/src/compiler/phases/2-analyze/visitors/LabeledStatement.js at line 12.
What does LabeledStatement() call?
LabeledStatement() calls 4 function(s): extract_identifiers, legacy_reactive_statement_invalid, object, reactive_declaration_invalid_placement.
Analyze Your Own Codebase
Get architecture documentation, dependency graphs, and domain analysis for your codebase in minutes.
Try Supermodel Free