Home / File/ LabeledStatement.js — svelte Source File

LabeledStatement.js — svelte Source File

Architecture documentation for LabeledStatement.js, a javascript file in the svelte codebase. 7 imports, 1 dependents.

File javascript Compiler Transformer 7 imports 1 dependents 1 functions

Entity Profile

Dependency Diagram

graph LR
  5d572700_84fa_a20f_b641_c5b7becd2684["LabeledStatement.js"]
  495501a4_a342_6a4d_ac11_e3e2fee8b218["errors.js"]
  5d572700_84fa_a20f_b641_c5b7becd2684 --> 495501a4_a342_6a4d_ac11_e3e2fee8b218
  a146f6ac_0088_8736_b6ce_318f9f115170["e"]
  5d572700_84fa_a20f_b641_c5b7becd2684 --> a146f6ac_0088_8736_b6ce_318f9f115170
  0c5c28a7_226d_4e7c_e75e_0853c0a9fc2c["ast.js"]
  5d572700_84fa_a20f_b641_c5b7becd2684 --> 0c5c28a7_226d_4e7c_e75e_0853c0a9fc2c
  c12e0147_3f27_cf17_5878_e54ffdc328d5["extract_identifiers"]
  5d572700_84fa_a20f_b641_c5b7becd2684 --> c12e0147_3f27_cf17_5878_e54ffdc328d5
  804afe56_25d1_9f41_dafe_adc75e952134["object"]
  5d572700_84fa_a20f_b641_c5b7becd2684 --> 804afe56_25d1_9f41_dafe_adc75e952134
  56a689f9_11c0_cc76_bd60_41bb6dc96475["warnings.js"]
  5d572700_84fa_a20f_b641_c5b7becd2684 --> 56a689f9_11c0_cc76_bd60_41bb6dc96475
  3246e0bc_b9fc_f638_5e35_41e8c39a2408["w"]
  5d572700_84fa_a20f_b641_c5b7becd2684 --> 3246e0bc_b9fc_f638_5e35_41e8c39a2408
  4aa8a188_84d4_0274_ed83_cac0ab1d3572["index.js"]
  4aa8a188_84d4_0274_ed83_cac0ab1d3572 --> 5d572700_84fa_a20f_b641_c5b7becd2684
  style 5d572700_84fa_a20f_b641_c5b7becd2684 fill:#6366f1,stroke:#818cf8,color:#fff

Relationship Graph

Source Code

/** @import { Expression, LabeledStatement } from 'estree' */
/** @import { AST, ReactiveStatement } from '#compiler' */
/** @import { Context } from '../types' */
import * as e from '../../../errors.js';
import { extract_identifiers, object } from '../../../utils/ast.js';
import * as w from '../../../warnings.js';

/**
 * @param {LabeledStatement} node
 * @param {Context} context
 */
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);
		}
	}

	context.next();
}

Domain

Subdomains

Functions

Frequently Asked Questions

What does LabeledStatement.js do?
LabeledStatement.js is a source file in the svelte codebase, written in javascript. It belongs to the Compiler domain, Transformer subdomain.
What functions are defined in LabeledStatement.js?
LabeledStatement.js defines 1 function(s): LabeledStatement.
What does LabeledStatement.js depend on?
LabeledStatement.js imports 7 module(s): ast.js, e, errors.js, extract_identifiers, object, w, warnings.js.
What files import LabeledStatement.js?
LabeledStatement.js is imported by 1 file(s): index.js.
Where is LabeledStatement.js in the architecture?
LabeledStatement.js is located at packages/svelte/src/compiler/phases/2-analyze/visitors/LabeledStatement.js (domain: Compiler, subdomain: Transformer, directory: packages/svelte/src/compiler/phases/2-analyze/visitors).

Analyze Your Own Codebase

Get architecture documentation, dependency graphs, and domain analysis for your codebase in minutes.

Try Supermodel Free