Commit 49882fa
## Summary
When every positional argument is unused, `F523` removes the entire
`.format(...)` call. That changes behavior whenever the format string
relies on the call:
* Brace escapes: `"{{".format("!")` returns `"{"`, but `"{{"` is two
characters.
* Named placeholders: `"{x}".format("!")` raises `KeyError`, but `"{x}"`
quietly succeeds.
This detects these cases and avoids removing the entire `format` call.
We also tried the "ideal" fix described on the issue of processing the
string to handle escapes ourselves, but just preserving the call seemed
like the better tradeoff in terms of complexity.
## Test plan
New mdtests based on the examples from the issue
Closes #15557
---------
Co-authored-by: Brent Westbrook <brentrwestbrook@gmail.com>
1 parent f46ee08 commit 49882fa
2 files changed
Lines changed: 57 additions & 13 deletions
File tree
- crates/ruff_linter
- resources/mdtest/pyflakes
- src/rules/pyflakes
Lines changed: 44 additions & 0 deletions
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
| 1 | + | |
| 2 | + | |
| 3 | + | |
| 4 | + | |
| 5 | + | |
| 6 | + | |
| 7 | + | |
| 8 | + | |
| 9 | + | |
| 10 | + | |
| 11 | + | |
| 12 | + | |
| 13 | + | |
| 14 | + | |
| 15 | + | |
| 16 | + | |
| 17 | + | |
| 18 | + | |
| 19 | + | |
| 20 | + | |
| 21 | + | |
| 22 | + | |
| 23 | + | |
| 24 | + | |
| 25 | + | |
| 26 | + | |
| 27 | + | |
| 28 | + | |
| 29 | + | |
| 30 | + | |
| 31 | + | |
| 32 | + | |
| 33 | + | |
| 34 | + | |
| 35 | + | |
| 36 | + | |
| 37 | + | |
| 38 | + | |
| 39 | + | |
| 40 | + | |
| 41 | + | |
| 42 | + | |
| 43 | + | |
| 44 | + | |
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
73 | 73 | | |
74 | 74 | | |
75 | 75 | | |
76 | | - | |
77 | | - | |
78 | | - | |
79 | | - | |
80 | | - | |
81 | | - | |
82 | | - | |
| 76 | + | |
| 77 | + | |
| 78 | + | |
| 79 | + | |
| 80 | + | |
| 81 | + | |
| 82 | + | |
| 83 | + | |
| 84 | + | |
| 85 | + | |
| 86 | + | |
| 87 | + | |
83 | 88 | | |
84 | 89 | | |
85 | 90 | | |
| |||
94 | 99 | | |
95 | 100 | | |
96 | 101 | | |
97 | | - | |
98 | | - | |
99 | | - | |
100 | | - | |
101 | | - | |
102 | | - | |
| 102 | + | |
103 | 103 | | |
104 | 104 | | |
105 | 105 | | |
| |||
0 commit comments