Commit bfe0323
authored
Rollup merge of rust-lang#126054 - veera-sivarajan:bugfix-113073-bound-on-generics-2, r=fee1-dead
`E0229`: Suggest Moving Type Constraints to Type Parameter Declaration
Fixes rust-lang#113073
This PR suggests `impl<T: Bound> Trait<T> for Foo` when finding `impl Trait<T: Bound> for Foo`. Tangentially, it also improves a handful of other error messages.
It accomplishes this in two steps:
1. Check if constrained arguments and parameter names appear in the same order and delay emitting "incorrect number of generic arguments" error because it can be confusing for the programmer to see `0 generic arguments provided` when there are `n` constrained generic arguments.
2. Inside `E0229`, suggest declaring the type parameter right after the `impl` keyword by finding the relevant impl block's span for type parameter declaration. This also handles lifetime declarations correctly.
Also, the multi part suggestion doesn't use the fluent error mechanism because translating all the errors to fluent style feels outside the scope of this PR. I will handle it in a separate PR if this gets approved.File tree
14 files changed
+263
-101
lines changed- compiler
- rustc_hir_analysis/src/hir_ty_lowering
- rustc_hir/src
- tests/ui
- associated-type-bounds
- associated-types
- async-await/return-type-notation
- const-generics/parser-error-recovery
- generics
14 files changed
+263
-101
lines changed| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
2471 | 2471 | | |
2472 | 2472 | | |
2473 | 2473 | | |
| 2474 | + | |
| 2475 | + | |
| 2476 | + | |
| 2477 | + | |
| 2478 | + | |
| 2479 | + | |
| 2480 | + | |
| 2481 | + | |
| 2482 | + | |
2474 | 2483 | | |
2475 | 2484 | | |
2476 | 2485 | | |
| |||
3763 | 3772 | | |
3764 | 3773 | | |
3765 | 3774 | | |
| 3775 | + | |
| 3776 | + | |
| 3777 | + | |
| 3778 | + | |
| 3779 | + | |
| 3780 | + | |
| 3781 | + | |
| 3782 | + | |
| 3783 | + | |
| 3784 | + | |
| 3785 | + | |
| 3786 | + | |
| 3787 | + | |
| 3788 | + | |
| 3789 | + | |
3766 | 3790 | | |
3767 | 3791 | | |
3768 | 3792 | | |
| |||
Lines changed: 62 additions & 9 deletions
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
1217 | 1217 | | |
1218 | 1218 | | |
1219 | 1219 | | |
1220 | | - | |
1221 | 1220 | | |
1222 | 1221 | | |
1223 | 1222 | | |
| |||
1263 | 1262 | | |
1264 | 1263 | | |
1265 | 1264 | | |
1266 | | - | |
| 1265 | + | |
1267 | 1266 | | |
1268 | 1267 | | |
1269 | 1268 | | |
| |||
1286 | 1285 | | |
1287 | 1286 | | |
1288 | 1287 | | |
1289 | | - | |
1290 | | - | |
| 1288 | + | |
1291 | 1289 | | |
1292 | 1290 | | |
1293 | 1291 | | |
1294 | | - | |
1295 | | - | |
1296 | | - | |
1297 | | - | |
1298 | | - | |
| 1292 | + | |
| 1293 | + | |
| 1294 | + | |
| 1295 | + | |
| 1296 | + | |
| 1297 | + | |
| 1298 | + | |
| 1299 | + | |
| 1300 | + | |
1299 | 1301 | | |
1300 | 1302 | | |
1301 | 1303 | | |
| 1304 | + | |
| 1305 | + | |
| 1306 | + | |
| 1307 | + | |
| 1308 | + | |
| 1309 | + | |
| 1310 | + | |
| 1311 | + | |
| 1312 | + | |
| 1313 | + | |
| 1314 | + | |
| 1315 | + | |
| 1316 | + | |
| 1317 | + | |
| 1318 | + | |
| 1319 | + | |
| 1320 | + | |
| 1321 | + | |
| 1322 | + | |
| 1323 | + | |
| 1324 | + | |
| 1325 | + | |
| 1326 | + | |
| 1327 | + | |
| 1328 | + | |
| 1329 | + | |
| 1330 | + | |
| 1331 | + | |
| 1332 | + | |
| 1333 | + | |
| 1334 | + | |
| 1335 | + | |
| 1336 | + | |
| 1337 | + | |
| 1338 | + | |
| 1339 | + | |
| 1340 | + | |
| 1341 | + | |
| 1342 | + | |
| 1343 | + | |
| 1344 | + | |
| 1345 | + | |
| 1346 | + | |
| 1347 | + | |
| 1348 | + | |
| 1349 | + | |
| 1350 | + | |
| 1351 | + | |
| 1352 | + | |
| 1353 | + | |
| 1354 | + | |
1302 | 1355 | | |
1303 | 1356 | | |
1304 | 1357 | | |
| |||
Lines changed: 16 additions & 1 deletion
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
531 | 531 | | |
532 | 532 | | |
533 | 533 | | |
| 534 | + | |
534 | 535 | | |
535 | 536 | | |
536 | 537 | | |
| |||
547 | 548 | | |
548 | 549 | | |
549 | 550 | | |
| 551 | + | |
| 552 | + | |
| 553 | + | |
| 554 | + | |
| 555 | + | |
| 556 | + | |
| 557 | + | |
| 558 | + | |
| 559 | + | |
| 560 | + | |
| 561 | + | |
| 562 | + | |
| 563 | + | |
| 564 | + | |
550 | 565 | | |
551 | 566 | | |
552 | 567 | | |
| |||
567 | 582 | | |
568 | 583 | | |
569 | 584 | | |
570 | | - | |
| 585 | + | |
571 | 586 | | |
572 | 587 | | |
573 | 588 | | |
| |||
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
5 | 5 | | |
6 | 6 | | |
7 | 7 | | |
| 8 | + | |
8 | 9 | | |
9 | 10 | | |
10 | 11 | | |
| |||
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
3 | 3 | | |
4 | 4 | | |
5 | 5 | | |
| 6 | + | |
| 7 | + | |
| 8 | + | |
| 9 | + | |
| 10 | + | |
6 | 11 | | |
7 | 12 | | |
8 | 13 | | |
| |||
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
76 | 76 | | |
77 | 77 | | |
78 | 78 | | |
79 | | - | |
80 | 79 | | |
81 | 80 | | |
82 | 81 | | |
| |||
92 | 91 | | |
93 | 92 | | |
94 | 93 | | |
95 | | - | |
96 | 94 | | |
97 | 95 | | |
98 | 96 | | |
| |||
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
5 | 5 | | |
6 | 6 | | |
7 | 7 | | |
8 | | - | |
9 | 8 | | |
10 | 9 | | |
11 | 10 | | |
| |||
14 | 13 | | |
15 | 14 | | |
16 | 15 | | |
17 | | - | |
| 16 | + | |
18 | 17 | | |
19 | 18 | | |
20 | 19 | | |
| |||
24 | 23 | | |
25 | 24 | | |
26 | 25 | | |
27 | | - | |
| 26 | + | |
28 | 27 | | |
29 | 28 | | |
30 | 29 | | |
| |||
34 | 33 | | |
35 | 34 | | |
36 | 35 | | |
37 | | - | |
| 36 | + | |
38 | 37 | | |
39 | 38 | | |
40 | 39 | | |
| |||
190 | 189 | | |
191 | 190 | | |
192 | 191 | | |
193 | | - | |
194 | | - | |
195 | | - | |
196 | | - | |
197 | | - | |
198 | | - | |
199 | | - | |
200 | | - | |
201 | | - | |
202 | | - | |
203 | | - | |
204 | | - | |
205 | | - | |
206 | | - | |
207 | | - | |
208 | | - | |
209 | 192 | | |
210 | 193 | | |
211 | 194 | | |
212 | 195 | | |
213 | 196 | | |
214 | 197 | | |
215 | 198 | | |
216 | | - | |
217 | 199 | | |
218 | 200 | | |
219 | 201 | | |
| |||
223 | 205 | | |
224 | 206 | | |
225 | 207 | | |
226 | | - | |
| 208 | + | |
227 | 209 | | |
228 | 210 | | |
229 | 211 | | |
| |||
239 | 221 | | |
240 | 222 | | |
241 | 223 | | |
242 | | - | |
| 224 | + | |
243 | 225 | | |
244 | 226 | | |
245 | 227 | | |
| |||
249 | 231 | | |
250 | 232 | | |
251 | 233 | | |
252 | | - | |
253 | | - | |
254 | | - | |
255 | | - | |
256 | | - | |
257 | | - | |
258 | | - | |
259 | | - | |
260 | | - | |
261 | | - | |
262 | | - | |
263 | | - | |
264 | | - | |
265 | | - | |
266 | | - | |
267 | | - | |
268 | 234 | | |
269 | | - | |
| 235 | + | |
270 | 236 | | |
271 | 237 | | |
272 | 238 | | |
| |||
277 | 243 | | |
278 | 244 | | |
279 | 245 | | |
280 | | - | |
| 246 | + | |
281 | 247 | | |
282 | 248 | | |
283 | 249 | | |
| |||
295 | 261 | | |
296 | 262 | | |
297 | 263 | | |
298 | | - | |
| 264 | + | |
299 | 265 | | |
300 | 266 | | |
301 | 267 | | |
| |||
306 | 272 | | |
307 | 273 | | |
308 | 274 | | |
309 | | - | |
| 275 | + | |
310 | 276 | | |
311 | 277 | | |
312 | 278 | | |
| |||
322 | 288 | | |
323 | 289 | | |
324 | 290 | | |
325 | | - | |
| 291 | + | |
326 | 292 | | |
327 | 293 | | |
328 | 294 | | |
| |||
333 | 299 | | |
334 | 300 | | |
335 | 301 | | |
336 | | - | |
| 302 | + | |
337 | 303 | | |
338 | 304 | | |
339 | 305 | | |
340 | 306 | | |
341 | 307 | | |
342 | | - | |
| 308 | + | |
343 | 309 | | |
344 | 310 | | |
345 | 311 | | |
| |||
349 | 315 | | |
350 | 316 | | |
351 | 317 | | |
352 | | - | |
| 318 | + | |
353 | 319 | | |
354 | 320 | | |
355 | 321 | | |
| |||
359 | 325 | | |
360 | 326 | | |
361 | 327 | | |
362 | | - | |
| 328 | + | |
363 | 329 | | |
364 | 330 | | |
365 | 331 | | |
0 commit comments