Skip to content

Commit

Permalink
fix destructuring to get multiple stores (sveltejs#5390)
Browse files Browse the repository at this point in the history
  • Loading branch information
tanhauhau authored and taylorzane committed Dec 17, 2020
1 parent d6487d2 commit 0f25fc3
Show file tree
Hide file tree
Showing 10 changed files with 71 additions and 22 deletions.
1 change: 1 addition & 0 deletions CHANGELOG.md
Original file line number Diff line number Diff line change
Expand Up @@ -5,6 +5,7 @@
* Fix specificity of certain styles involving a child selector ([#4795](https://github.com/sveltejs/svelte/issues/4795))
* Fix transitions that are parameterised with stores ([#5244](https://github.com/sveltejs/svelte/issues/5244))
* Fix scoping of styles involving child selector and `*` ([#5370](https://github.com/sveltejs/svelte/issues/5370))
* Fix destructuring which reassigns stores ([#5388](https://github.com/sveltejs/svelte/issues/5388))

## 3.25.0

Expand Down
10 changes: 3 additions & 7 deletions src/compiler/compile/Component.ts
Original file line number Diff line number Diff line change
Expand Up @@ -947,12 +947,6 @@ export default class Component {
const variable = component.var_lookup.get(name);

if (variable.export_name && variable.writable) {
const insert = variable.subscribable
? get_insert(variable)
: null;

parent[key].splice(index + 1, 0, insert);

declarator.id = {
type: 'ObjectPattern',
properties: [{
Expand All @@ -973,7 +967,9 @@ export default class Component {
};

declarator.init = x`$$props`;
} else if (variable.subscribable) {
}

if (variable.subscribable && declarator.init) {
const insert = get_insert(variable);
parent[key].splice(index + 1, 0, ...insert);
}
Expand Down
6 changes: 4 additions & 2 deletions src/compiler/compile/render_dom/Renderer.ts
Original file line number Diff line number Diff line change
Expand Up @@ -166,12 +166,14 @@ export default class Renderer {
return member;
}

invalidate(name: string, value?) {
invalidate(name: string, value?, main_execution_context: boolean = false) {
const variable = this.component.var_lookup.get(name);
const member = this.context_lookup.get(name);

if (variable && (variable.subscribable && (variable.reassigned || variable.export_name))) {
return x`${`$$subscribe_${name}`}($$invalidate(${member.index}, ${value || name}))`;
return main_execution_context
? x`${`$$subscribe_${name}`}(${value || name})`
: x`${`$$subscribe_${name}`}($$invalidate(${member.index}, ${value || name}))`;
}

if (name[0] === '$' && name[1] !== '$') {
Expand Down
20 changes: 12 additions & 8 deletions src/compiler/compile/render_dom/invalidate.ts
Original file line number Diff line number Diff line change
Expand Up @@ -31,10 +31,9 @@ export function invalidate(renderer: Renderer, scope: Scope, node: Node, names:

function get_invalidated(variable: Var, node?: Expression) {
if (main_execution_context && !variable.subscribable && variable.name[0] !== '$') {
return node || x`${variable.name}`;
return node;
}

return renderer.invalidate(variable.name);
return renderer.invalidate(variable.name, undefined, main_execution_context);
}

if (head) {
Expand All @@ -44,12 +43,15 @@ export function invalidate(renderer: Renderer, scope: Scope, node: Node, names:
return get_invalidated(head, node);
} else {
const is_store_value = head.name[0] === '$' && head.name[1] !== '$';
const extra_args = tail.map(variable => get_invalidated(variable));
const extra_args = tail.map(variable => get_invalidated(variable)).filter(Boolean);

const pass_value = (
extra_args.length > 0 ||
(node.type === 'AssignmentExpression' && node.left.type !== 'Identifier') ||
(node.type === 'UpdateExpression' && (!node.prefix || node.argument.type !== 'Identifier'))
!main_execution_context &&
(
extra_args.length > 0 ||
(node.type === 'AssignmentExpression' && node.left.type !== 'Identifier') ||
(node.type === 'UpdateExpression' && (!node.prefix || node.argument.type !== 'Identifier'))
)
);

if (pass_value) {
Expand All @@ -63,7 +65,9 @@ export function invalidate(renderer: Renderer, scope: Scope, node: Node, names:
? x`@set_store_value(${head.name.slice(1)}, ${node}, ${extra_args})`
: !main_execution_context
? x`$$invalidate(${renderer.context_lookup.get(head.name).index}, ${node}, ${extra_args})`
: node;
: extra_args.length
? [node, ...extra_args]
: node;

if (head.subscribable && head.reassigned) {
const subscribe = `$$subscribe_${head.name}`;
Expand Down
Original file line number Diff line number Diff line change
@@ -0,0 +1,3 @@
export default {
html: `<h1>2 2 xxx 5 6</h1>`
};
Original file line number Diff line number Diff line change
@@ -0,0 +1,16 @@
<script>
import { writable } from 'svelte/store';
let eid = writable(1);
let foo;
let u;
let v;
let w;
[u, v, w] = [
{id: eid = writable(foo = 2), name: 'xxx'},
5,
writable(6)
];
</script>

<h1>{foo} {$eid} {u.name} {v} {$w}</h1>
Original file line number Diff line number Diff line change
@@ -1,6 +1,9 @@
<script>
let foo;
let bar = (foo = 1);
function a() {
bar = (foo = 1);
}
</script>

<h1>{foo} {bar}</h1>
Original file line number Diff line number Diff line change
@@ -1,9 +1,14 @@
<script>
let foo1;
let foo2;
for (let bar = (foo1 = 0); bar < 5; bar += 1) {
foo2 = foo1;
}
let foo1;
let foo2;
for (let bar = (foo1 = 0); bar < 5; bar += 1) {
foo2 = foo1;
}
function a() {
for (let bar = (foo1 = 0); bar < 5; bar += 1) {
foo2 = foo1;
}
}
</script>

<h1>{foo1} {foo2}</h1>
3 changes: 3 additions & 0 deletions test/runtime/samples/store-resubscribe-c/_config.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,3 @@
export default {
html: `31 42`
};
16 changes: 16 additions & 0 deletions test/runtime/samples/store-resubscribe-c/main.svelte
Original file line number Diff line number Diff line change
@@ -0,0 +1,16 @@
<script>
import { writable } from 'svelte/store';
const context = {
store1: writable(31),
store2: writable(42)
};
let store1;
let store2;
({
store1,
store2
} = context);
</script>

{$store1}
{$store2}

0 comments on commit 0f25fc3

Please sign in to comment.