don't warn when using each index in key (#3274)

pull/3336/head
Conduitry 6 years ago
parent 981f30d3e9
commit c04def9081

@ -83,16 +83,16 @@ export default class EachBlock extends AbstractBlock {
this.scope.add(context.key.name, this.expression.dependencies, this); this.scope.add(context.key.name, this.expression.dependencies, this);
}); });
this.key = info.key
? new Expression(component, this, this.scope, info.key)
: null;
if (this.index) { if (this.index) {
// index can only change if this is a keyed each block // index can only change if this is a keyed each block
const dependencies = this.key ? this.expression.dependencies : new Set([]); const dependencies = info.key ? this.expression.dependencies : new Set([]);
this.scope.add(this.index, dependencies, this); this.scope.add(this.index, dependencies, this);
} }
this.key = info.key
? new Expression(component, this, this.scope, info.key)
: null;
this.has_animation = false; this.has_animation = false;
this.children = map_children(component, this, this.scope, info.children); this.children = map_children(component, this, this.scope, info.children);

@ -1,6 +1,6 @@
<script>
// script block prevents auto-declaration
</script>
<p>{potato}</p> <p>{potato}</p>
<p>{Math.max(1, 2)}</p> <p>{Math.max(1, 2)}</p>
{#each window.something as foo, i (foo.x + i)}
hello
{/each}

@ -1,15 +1,15 @@
[{ [{
"code": "missing-declaration", "code": "missing-declaration",
"message": "'potato' is not defined", "message": "'potato' is not defined. Consider adding a <script> block with 'export let potato' to declare a prop",
"pos": 67, "pos": 4,
"start": { "start": {
"line": 5, "line": 1,
"column": 4, "column": 4,
"character": 67 "character": 4
}, },
"end": { "end": {
"line": 5, "line": 1,
"column": 10, "column": 10,
"character": 73 "character": 10
} }
}] }]
Loading…
Cancel
Save