Skip to content
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
3 changes: 1 addition & 2 deletions packages/svelte/src/compiler/phases/1-parse/utils/create.js
Original file line number Diff line number Diff line change
Expand Up @@ -12,8 +12,7 @@ export function create_fragment(transparent = false) {
metadata: {
transparent,
dynamic: false,
has_await: false,
is_async: false
has_await: false
}
};
}
Original file line number Diff line number Diff line change
Expand Up @@ -43,10 +43,6 @@ export function AwaitBlock(node, context) {

context.visit(node.expression, { ...context.state, expression: node.metadata.expression });

if (node.metadata.expression.has_await && context.state.fragment) {
context.state.fragment.metadata.is_async = true;
}

if (node.pending) context.visit(node.pending);
if (node.then) context.visit(node.then);
if (node.catch) context.visit(node.catch);
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -35,11 +35,6 @@ export function EachBlock(node, context) {
scope: /** @type {Scope} */ (context.state.scope.parent)
});

// TODO it should be impossible to be in the template and not have a fragment...
if (node.metadata.expression.has_await && context.state.fragment) {
context.state.fragment.metadata.is_async = true;
}

context.visit(node.body);
if (node.key) context.visit(node.key);
if (node.fallback) context.visit(node.fallback);
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -22,10 +22,6 @@ export function IfBlock(node, context) {
expression: node.metadata.expression
});

if (node.metadata.expression.has_await && context.state.fragment) {
context.state.fragment.metadata.is_async = true;
}

context.visit(node.consequent);
if (node.alternate) context.visit(node.alternate);
}
Original file line number Diff line number Diff line change
@@ -1,29 +1,33 @@
/** @import { BlockStatement, Expression, Pattern } from 'estree' */
/** @import { BlockStatement, Expression, Pattern, Statement } from 'estree' */
/** @import { AST } from '#compiler' */
/** @import { ComponentContext } from '../types.js' */
import * as b from '#compiler/builders';
import { block_close } from './shared/utils.js';
import { block_close, call_child_payload } from './shared/utils.js';

/**
* @param {AST.AwaitBlock} node
* @param {ComponentContext} context
*/
export function AwaitBlock(node, context) {
context.state.template.push(
b.stmt(
b.call(
'$.await',
b.id('$$payload'),
/** @type {Expression} */ (context.visit(node.expression)),
b.thunk(
node.pending ? /** @type {BlockStatement} */ (context.visit(node.pending)) : b.block([])
),
b.arrow(
node.value ? [/** @type {Pattern} */ (context.visit(node.value))] : [],
node.then ? /** @type {BlockStatement} */ (context.visit(node.then)) : b.block([])
)
/** @type {Statement} */
let statement = b.stmt(
b.call(
'$.await',
b.id('$$payload'),
/** @type {Expression} */ (context.visit(node.expression)),
b.thunk(
node.pending ? /** @type {BlockStatement} */ (context.visit(node.pending)) : b.block([])
),
b.arrow(
node.value ? [/** @type {Pattern} */ (context.visit(node.value))] : [],
node.then ? /** @type {BlockStatement} */ (context.visit(node.then)) : b.block([])
)
),
block_close
)
);

if (node.metadata.expression.has_await) {
statement = call_child_payload(b.block([statement]), true);
}

context.state.template.push(statement, block_close);
}
Original file line number Diff line number Diff line change
Expand Up @@ -2,7 +2,7 @@
/** @import { AST } from '#compiler' */
/** @import { ComponentContext } from '../types.js' */
import * as b from '#compiler/builders';
import { block_close, block_open, block_open_else } from './shared/utils.js';
import { block_close, block_open, block_open_else, call_child_payload } from './shared/utils.js';

/**
* @param {AST.EachBlock} node
Expand All @@ -17,7 +17,9 @@ export function EachBlock(node, context) {
each_node_meta.contains_group_binding || !node.index ? each_node_meta.index : b.id(node.index);

const array_id = state.scope.root.unique('each_array');
state.init.push(b.const(array_id, b.call('$.ensure_array_like', collection)));

/** @type {Statement} */
let block = b.block([b.const(array_id, b.call('$.ensure_array_like', collection))]);

/** @type {Statement[]} */
const each = [];
Expand Down Expand Up @@ -47,19 +49,23 @@ export function EachBlock(node, context) {

const fallback = /** @type {BlockStatement} */ (context.visit(node.fallback));

fallback.body.unshift(
b.stmt(b.call(b.member(b.id('$$payload'), b.id('push')), block_open_else))
);
fallback.body.unshift(b.stmt(b.call(b.id('$$payload.push'), block_open_else)));

state.template.push(
block.body.push(
b.if(
b.binary('!==', b.member(array_id, 'length'), b.literal(0)),
b.block([open, for_loop]),
fallback
),
block_close
)
);
} else {
state.template.push(block_open, for_loop, block_close);
state.template.push(block_open);
block.body.push(for_loop);
}

if (node.metadata.expression.has_await) {
state.template.push(call_child_payload(block, true), block_close);
} else {
state.template.push(...block.body, block_close);
}
}
Original file line number Diff line number Diff line change
@@ -1,14 +1,8 @@
/** @import { AST } from '#compiler' */
/** @import { Statement } from 'estree' */
/** @import { ComponentContext, ComponentServerTransformState } from '../types.js' */
import { clean_nodes, infer_namespace } from '../../utils.js';
import * as b from '#compiler/builders';
import {
empty_comment,
process_children,
build_template,
call_child_payload
} from './shared/utils.js';
import { empty_comment, process_children, build_template } from './shared/utils.js';

/**
* @param {AST.Fragment} node
Expand Down Expand Up @@ -48,15 +42,5 @@ export function Fragment(node, context) {

process_children(trimmed, { ...context, state });

if (node.metadata.is_async) {
/** @type {Statement[]} */
const statements = [];

statements.push(...state.init);
statements.push(...build_template(state.template));

return b.block([call_child_payload(b.block(statements), true)]);
}

return b.block([...state.init, ...build_template(state.template)]);
}
Original file line number Diff line number Diff line change
@@ -1,8 +1,8 @@
/** @import { BlockStatement, Expression } from 'estree' */
/** @import { BlockStatement, Expression, Statement } from 'estree' */
/** @import { AST } from '#compiler' */
/** @import { ComponentContext } from '../types.js' */
import * as b from '#compiler/builders';
import { block_close, block_open, block_open_else } from './shared/utils.js';
import { block_close, block_open, block_open_else, call_child_payload } from './shared/utils.js';

/**
* @param {AST.IfBlock} node
Expand All @@ -22,5 +22,12 @@ export function IfBlock(node, context) {
b.stmt(b.call(b.member(b.id('$$payload'), b.id('push')), block_open_else))
);

context.state.template.push(b.if(test, consequent, alternate), block_close);
/** @type {Statement} */
let statement = b.if(test, consequent, alternate);

if (node.metadata.expression.has_await) {
statement = call_child_payload(b.block([statement]), true);
}

context.state.template.push(statement, block_close);
}
Original file line number Diff line number Diff line change
Expand Up @@ -178,8 +178,7 @@ export function RegularElement(node, context) {
b.id('$$payload'),
b.arrow(
[b.id('$$payload')],
b.block([...inner_state.init, ...build_template(inner_state.template)]),
node.fragment.metadata.is_async
b.block([...inner_state.init, ...build_template(inner_state.template)])
)
)
)
Expand Down Expand Up @@ -207,11 +206,7 @@ export function RegularElement(node, context) {
)
);
} else {
if (node.fragment.metadata.is_async) {
state.template.push(/** @type {Statement} */ (context.visit(node.fragment)));
} else {
process_children(trimmed, { ...context, state });
}
process_children(trimmed, { ...context, state });
}

if (select_with_value) {
Expand Down
2 changes: 0 additions & 2 deletions packages/svelte/src/compiler/types/template.d.ts
Original file line number Diff line number Diff line change
Expand Up @@ -57,8 +57,6 @@ export namespace AST {
*/
dynamic: boolean;
has_await: boolean;
/** TODO document */
is_async: boolean;
};
}

Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -18,7 +18,7 @@ export default function Async_each_fallback_hoisting($$payload) {
$$payload.push(`<!---->`);
$$payload.push(async () => $.escape(await Promise.resolve(4)));
}

$$payload.push(`<!--]-->`);
});

$$payload.push(`<!--]-->`);
}
Original file line number Diff line number Diff line change
Expand Up @@ -5,18 +5,18 @@ export default function Async_each_hoisting($$payload) {
const second = Promise.resolve(2);
const third = Promise.resolve(3);

$$payload.push(`<!--[-->`);

$$payload.child(async ($$payload) => {
const each_array = $.ensure_array_like(await Promise.resolve([first, second, third]));

$$payload.push(`<!--[-->`);

for (let $$index = 0, $$length = each_array.length; $$index < $$length; $$index++) {
let item = each_array[$$index];

$$payload.push(`<!---->`);
$$payload.push(async () => $.escape(await item));
}

$$payload.push(`<!--]-->`);
});

$$payload.push(`<!--]-->`);
}
Original file line number Diff line number Diff line change
Expand Up @@ -9,7 +9,7 @@ export default function Async_if_alternate_hoisting($$payload) {
$$payload.push('<!--[!-->');
$$payload.push(async () => $.escape(await Promise.resolve('yes yes yes')));
}

$$payload.push(`<!--]-->`);
});

$$payload.push(`<!--]-->`);
}
Original file line number Diff line number Diff line change
Expand Up @@ -9,7 +9,7 @@ export default function Async_if_hoisting($$payload) {
$$payload.push('<!--[!-->');
$$payload.push(async () => $.escape(await Promise.reject('no no no')));
}

$$payload.push(`<!--]-->`);
});

$$payload.push(`<!--]-->`);
}
Original file line number Diff line number Diff line change
@@ -1,10 +1,10 @@
import * as $ from 'svelte/internal/server';

export default function Delegated_locally_declared_shadowed($$payload) {
const each_array = $.ensure_array_like({ length: 1 });

$$payload.push(`<!--[-->`);

const each_array = $.ensure_array_like({ length: 1 });

for (let index = 0, $$length = each_array.length; index < $$length; index++) {
$$payload.push(`<button type="button"${$.attr('data-index', index)}>B</button>`);
}
Expand Down
Original file line number Diff line number Diff line change
@@ -1,10 +1,10 @@
import * as $ from 'svelte/internal/server';

export default function Each_index_non_null($$payload) {
const each_array = $.ensure_array_like(Array(10));

$$payload.push(`<!--[-->`);

const each_array = $.ensure_array_like(Array(10));

for (let i = 0, $$length = each_array.length; i < $$length; i++) {
$$payload.push(`<p>index: ${$.escape(i)}</p>`);
}
Expand Down
Original file line number Diff line number Diff line change
@@ -1,10 +1,10 @@
import * as $ from 'svelte/internal/server';

export default function Each_string_template($$payload) {
const each_array = $.ensure_array_like(['foo', 'bar', 'baz']);

$$payload.push(`<!--[-->`);

const each_array = $.ensure_array_like(['foo', 'bar', 'baz']);

for (let $$index = 0, $$length = each_array.length; $$index < $$length; $$index++) {
let thing = each_array[$$index];

Expand Down
Loading