fix: silence false-positive statel value warning (#14958)

fixes #14687
pull/14953/head
Simon H 3 days ago committed by GitHub
parent a2565efa37
commit 9aae463ae1
No known key found for this signature in database
GPG Key ID: B5690EEEBB952194

@ -0,0 +1,5 @@
---
'svelte': patch
---
fix: silence false-positive stale value warning

@ -171,6 +171,7 @@ function build_assignment(operator, left, right, context) {
// special case — ignore `bind:prop={getter, (v) => (...)}` / `bind:value={x.y}` // special case — ignore `bind:prop={getter, (v) => (...)}` / `bind:value={x.y}`
if ( if (
path.at(-1) === 'BindDirective' ||
path.at(-1) === 'Component' || path.at(-1) === 'Component' ||
path.at(-1) === 'SvelteComponent' || path.at(-1) === 'SvelteComponent' ||
(path.at(-1) === 'ArrowFunctionExpression' && (path.at(-1) === 'ArrowFunctionExpression' &&

@ -1,21 +1,33 @@
import { flushSync } from 'svelte'; import { flushSync } from 'svelte';
import { test } from '../../test'; import { ok, test } from '../../test';
export default test({ export default test({
compileOptions: { compileOptions: {
dev: true dev: true
}, },
html: `<button>items: null</button> <div>x</div>`, html: `<button>items: null</button> <div>x</div> <input type="checkbox" value="1"><input type="checkbox" value="2">`,
test({ assert, target, warnings }) { test({ assert, target, warnings }) {
const btn = target.querySelector('button'); const btn = target.querySelector('button');
ok(btn);
flushSync(() => btn?.click()); flushSync(() => btn.click());
assert.htmlEqual(target.innerHTML, `<button>items: []</button> <div>x</div>`); assert.htmlEqual(
target.innerHTML,
`<button>items: []</button> <div>x</div> <input type="checkbox" value="1"><input type="checkbox" value="2">`
);
flushSync(() => btn?.click()); flushSync(() => btn.click());
assert.htmlEqual(target.innerHTML, `<button>items: [0]</button> <div>x</div>`); assert.htmlEqual(
target.innerHTML,
`<button>items: [0]</button> <div>x</div> <input type="checkbox" value="1"><input type="checkbox" value="2">`
);
const input = target.querySelector('input');
ok(input);
input.checked = true;
flushSync(() => input.dispatchEvent(new Event('change', { bubbles: true })));
assert.deepEqual(warnings, [ assert.deepEqual(warnings, [
'Assignment to `items` property (main.svelte:8:24) will evaluate to the right-hand side, not the value of `items` following the assignment. This may result in unexpected behaviour.' 'Assignment to `items` property (main.svelte:8:24) will evaluate to the right-hand side, not the value of `items` following the assignment. This may result in unexpected behaviour.'

@ -2,7 +2,7 @@
import Test from './Test.svelte'; import Test from './Test.svelte';
let entries = $state([]); let entries = $state([]);
let object = $state({ items: null }); let object = $state({ items: null, group: [] });
</script> </script>
<button onclick={() => (object.items ??= []).push(object.items.length)}> <button onclick={() => (object.items ??= []).push(object.items.length)}>
@ -11,6 +11,8 @@
<!-- these should not emit warnings --> <!-- these should not emit warnings -->
<div bind:this={entries[0]}>x</div> <div bind:this={entries[0]}>x</div>
<input type="checkbox" value=1 bind:group={object.group}>
<input type="checkbox" value=2 bind:group={object.group}>
<Test bind:this={entries[1]}></Test> <Test bind:this={entries[1]}></Test>
<Test bind:this={() => entries[2], (v) => (entries[2] = v)}></Test> <Test bind:this={() => entries[2], (v) => (entries[2] = v)}></Test>
<Test bind:x={entries[3]}></Test> <Test bind:x={entries[3]}></Test>

Loading…
Cancel
Save