Skip to content

Commit fc181cf

Browse files
authored
chore: move $effect visitors (#17041)
1 parent 9096680 commit fc181cf

File tree

2 files changed

+11
-10
lines changed

2 files changed

+11
-10
lines changed

packages/svelte/src/compiler/phases/3-transform/client/visitors/CallExpression.js

Lines changed: 11 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -62,6 +62,17 @@ export function CallExpression(node, context) {
6262
is_ignored(node, 'state_snapshot_uncloneable') && b.true
6363
);
6464

65+
case '$effect':
66+
case '$effect.pre': {
67+
const callee = rune === '$effect' ? '$.user_effect' : '$.user_pre_effect';
68+
const func = /** @type {Expression} */ (context.visit(node.arguments[0]));
69+
70+
const expr = b.call(callee, /** @type {Expression} */ (func));
71+
expr.callee.loc = node.callee.loc; // ensure correct mapping
72+
73+
return expr;
74+
}
75+
6576
case '$effect.root':
6677
return b.call(
6778
'$.effect_root',

packages/svelte/src/compiler/phases/3-transform/client/visitors/ExpressionStatement.js

Lines changed: 0 additions & 10 deletions
Original file line numberDiff line numberDiff line change
@@ -11,16 +11,6 @@ export function ExpressionStatement(node, context) {
1111
if (node.expression.type === 'CallExpression') {
1212
const rune = get_rune(node.expression, context.state.scope);
1313

14-
if (rune === '$effect' || rune === '$effect.pre') {
15-
const callee = rune === '$effect' ? '$.user_effect' : '$.user_pre_effect';
16-
const func = /** @type {Expression} */ (context.visit(node.expression.arguments[0]));
17-
18-
const expr = b.call(callee, /** @type {Expression} */ (func));
19-
expr.callee.loc = node.expression.callee.loc; // ensure correct mapping
20-
21-
return b.stmt(expr);
22-
}
23-
2414
if (rune === '$inspect.trace') {
2515
return b.empty;
2616
}

0 commit comments

Comments
 (0)