basic client-side await-then-catch working

pull/952/head
Rich Harris 7 years ago
parent d783993d23
commit a2d885c8ba

@ -124,6 +124,8 @@ const preprocessors = {
node.var = block.getUniqueName('await_block'); node.var = block.getUniqueName('await_block');
block.addDependencies(node.metadata.dependencies); block.addDependencies(node.metadata.dependencies);
let dynamic = false;
[ [
['pending', null], ['pending', null],
['then', node.value], ['then', node.value],
@ -147,7 +149,16 @@ const preprocessors = {
preprocessChildren(generator, child._block, child._state, child, inEachBlock, elementStack, componentStack, stripWhitespace, nextSibling); preprocessChildren(generator, child._block, child._state, child, inEachBlock, elementStack, componentStack, stripWhitespace, nextSibling);
generator.blocks.push(child._block); generator.blocks.push(child._block);
if (child._block.dependencies.size > 0) {
dynamic = true;
block.addDependencies(child._block.dependencies);
}
}); });
node.pending._block.hasUpdateMethod = dynamic;
node.then._block.hasUpdateMethod = dynamic;
node.catch._block.hasUpdateMethod = dynamic;
}, },
IfBlock: ( IfBlock: (

@ -51,15 +51,6 @@ export default function visitAwaitBlock(
const create_then_block = node.then._block.name; const create_then_block = node.then._block.name;
const create_catch_block = node.catch._block.name; const create_catch_block = node.catch._block.name;
const conditions = [];
if (node.metadata.dependencies) {
conditions.push(
`(${node.metadata.dependencies.map(dep => `'${dep}' in changed`).join(' || ')})`
);
}
conditions.push(`${promise} !== (${promise} = ${snippet})`);
block.addVariable(await_block); block.addVariable(await_block);
block.addVariable(await_block_type); block.addVariable(await_block_type);
block.addVariable(await_token); block.addVariable(await_token);
@ -89,7 +80,10 @@ export default function visitAwaitBlock(
// if we previously had a then/catch block, destroy it // if we previously had a then/catch block, destroy it
if (${await_block_type} !== ${create_pending_block}) { if (${await_block_type} !== ${create_pending_block}) {
if (${await_block}) ${await_block}.d(); if (${await_block}) {
${await_block}.u();
${await_block}.d();
}
${await_block} = (${await_block_type} = ${create_pending_block})(${params}, ${resolved} = null, #component); ${await_block} = (${await_block_type} = ${create_pending_block})(${params}, ${resolved} = null, #component);
return true; return true;
} }
@ -120,6 +114,36 @@ export default function visitAwaitBlock(
${await_block}.m(${targetNode}, ${anchor}); ${await_block}.m(${targetNode}, ${anchor});
`); `);
const conditions = [];
if (node.metadata.dependencies) {
conditions.push(
`(${node.metadata.dependencies.map(dep => `'${dep}' in changed`).join(' || ')})`
);
}
conditions.push(
`${promise} !== (${promise} = ${snippet})`,
`${handle_promise}(${promise}, ${params})`
);
if (node.pending._block.hasUpdateMethod) {
block.builders.update.addBlock(deindent`
if (${conditions.join(' && ')}) {
${await_block}.c();
${await_block}.m(${anchor}.parentNode, ${anchor});
} else {
${await_block}.p(changed, ${params}, ${resolved});
}
`);
} else {
block.builders.update.addBlock(deindent`
if (${conditions.join(' && ')}) {
${await_block}.c();
${await_block}.m(${anchor}.parentNode, ${anchor});
}
`);
}
block.builders.destroy.addBlock(deindent` block.builders.destroy.addBlock(deindent`
${await_token} = null; ${await_token} = null;
${await_block}.d(); ${await_block}.d();

@ -5,8 +5,6 @@ let thePromise = new Promise(f => {
}); });
export default { export default {
solo: true,
data: { data: {
thePromise thePromise
}, },
@ -38,7 +36,12 @@ export default {
`); `);
reject(new Error('something broke')); reject(new Error('something broke'));
try {
await thePromise; await thePromise;
} catch (err) {
// do nothing
}
assert.htmlEqual(target.innerHTML, ` assert.htmlEqual(target.innerHTML, `
<p>oh no! something broke</p> <p>oh no! something broke</p>

Loading…
Cancel
Save