-
Notifications
You must be signed in to change notification settings - Fork 12.7k
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Rollup merge of #127717 - gurry:127441-stray-impl-sugg, r=compiler-er…
…rors Fix malformed suggestion for repeated maybe unsized bounds Fixes #127441 Now when we encounter something like `foo(a : impl ?Sized + ?Sized)`, instead of suggesting removal of both bounds and leaving `foo(a: impl )` behind, we suggest changing the first bound to `Sized` and removing the second bound, resulting in `foo(a: impl Sized)`. Although the issue was reported for impl trait types, it also occurred with regular param bounds. So if we encounter `foo<T: ?Sized + ?Sized>(a: T)` we now detect that all the bounds are `?Sized` and therefore emit the suggestion to remove the entire predicate `: ?Sized + ?Sized` resulting in `foo<T>(a: T)`. Lastly, if we encounter a situation where some of the bounds are something other than `?Sized`, then we emit separate removal suggestions for each `?Sized` bound. E.g. if we see `foo(a: impl ?Sized + Bar + ?Sized)` or `foo<T: ?Sized + Bar + ?Sized>(a: T)` we emit suggestions such that the user will be left with `foo(a : impl Bar)` or `foo<T: Bar>(a: T)` respectively.
- Loading branch information
Showing
4 changed files
with
295 additions
and
29 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
39 changes: 39 additions & 0 deletions
39
tests/ui/trait-bounds/bad-suggestionf-for-repeated-unsized-bound-127441.rs
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,39 @@ | ||
// Regression test for #127441 | ||
|
||
// Tests that we make the correct suggestion | ||
// in case there are more than one `?Sized` | ||
// bounds on a function parameter | ||
|
||
use std::fmt::Debug; | ||
|
||
fn foo1<T: ?Sized>(a: T) {} | ||
//~^ ERROR he size for values of type `T` cannot be known at compilation time | ||
|
||
fn foo2<T: ?Sized + ?Sized>(a: T) {} | ||
//~^ ERROR type parameter has more than one relaxed default bound, only one is supported | ||
//~| ERROR the size for values of type `T` cannot be known at compilation time | ||
|
||
fn foo3<T: ?Sized + ?Sized + Debug>(a: T) {} | ||
//~^ ERROR type parameter has more than one relaxed default bound, only one is supported | ||
//~| ERROR he size for values of type `T` cannot be known at compilation time | ||
|
||
fn foo4<T: ?Sized + Debug + ?Sized >(a: T) {} | ||
//~^ ERROR type parameter has more than one relaxed default bound, only one is supported | ||
//~| ERROR the size for values of type `T` cannot be known at compilation time | ||
|
||
fn foo5(_: impl ?Sized) {} | ||
//~^ ERROR the size for values of type `impl ?Sized` cannot be known at compilation time | ||
|
||
fn foo6(_: impl ?Sized + ?Sized) {} | ||
//~^ ERROR type parameter has more than one relaxed default bound, only one is supported | ||
//~| ERROR the size for values of type `impl ?Sized + ?Sized` cannot be known at compilation tim | ||
|
||
fn foo7(_: impl ?Sized + ?Sized + Debug) {} | ||
//~^ ERROR type parameter has more than one relaxed default bound, only one is supported | ||
//~| ERROR the size for values of type `impl ?Sized + ?Sized + Debug` cannot be known at compilation time | ||
|
||
fn foo8(_: impl ?Sized + Debug + ?Sized ) {} | ||
//~^ ERROR type parameter has more than one relaxed default bound, only one is supported | ||
//~| ERROR the size for values of type `impl ?Sized + Debug + ?Sized` cannot be known at compilation time | ||
|
||
fn main() {} |
192 changes: 192 additions & 0 deletions
192
tests/ui/trait-bounds/bad-suggestionf-for-repeated-unsized-bound-127441.stderr
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,192 @@ | ||
error[E0203]: type parameter has more than one relaxed default bound, only one is supported | ||
--> $DIR/bad-suggestionf-for-repeated-unsized-bound-127441.rs:12:12 | ||
| | ||
LL | fn foo2<T: ?Sized + ?Sized>(a: T) {} | ||
| ^^^^^^ ^^^^^^ | ||
|
||
error[E0203]: type parameter has more than one relaxed default bound, only one is supported | ||
--> $DIR/bad-suggestionf-for-repeated-unsized-bound-127441.rs:16:12 | ||
| | ||
LL | fn foo3<T: ?Sized + ?Sized + Debug>(a: T) {} | ||
| ^^^^^^ ^^^^^^ | ||
|
||
error[E0203]: type parameter has more than one relaxed default bound, only one is supported | ||
--> $DIR/bad-suggestionf-for-repeated-unsized-bound-127441.rs:20:12 | ||
| | ||
LL | fn foo4<T: ?Sized + Debug + ?Sized >(a: T) {} | ||
| ^^^^^^ ^^^^^^ | ||
|
||
error[E0203]: type parameter has more than one relaxed default bound, only one is supported | ||
--> $DIR/bad-suggestionf-for-repeated-unsized-bound-127441.rs:27:17 | ||
| | ||
LL | fn foo6(_: impl ?Sized + ?Sized) {} | ||
| ^^^^^^ ^^^^^^ | ||
|
||
error[E0203]: type parameter has more than one relaxed default bound, only one is supported | ||
--> $DIR/bad-suggestionf-for-repeated-unsized-bound-127441.rs:31:17 | ||
| | ||
LL | fn foo7(_: impl ?Sized + ?Sized + Debug) {} | ||
| ^^^^^^ ^^^^^^ | ||
|
||
error[E0203]: type parameter has more than one relaxed default bound, only one is supported | ||
--> $DIR/bad-suggestionf-for-repeated-unsized-bound-127441.rs:35:17 | ||
| | ||
LL | fn foo8(_: impl ?Sized + Debug + ?Sized ) {} | ||
| ^^^^^^ ^^^^^^ | ||
|
||
error[E0277]: the size for values of type `T` cannot be known at compilation time | ||
--> $DIR/bad-suggestionf-for-repeated-unsized-bound-127441.rs:9:20 | ||
| | ||
LL | fn foo1<T: ?Sized>(a: T) {} | ||
| - ^ doesn't have a size known at compile-time | ||
| | | ||
| this type parameter needs to be `Sized` | ||
| | ||
= help: unsized fn params are gated as an unstable feature | ||
help: consider removing the `?Sized` bound to make the type parameter `Sized` | ||
| | ||
LL - fn foo1<T: ?Sized>(a: T) {} | ||
LL + fn foo1<T>(a: T) {} | ||
| | ||
help: function arguments must have a statically known size, borrowed types always have a known size | ||
| | ||
LL | fn foo1<T: ?Sized>(a: &T) {} | ||
| + | ||
|
||
error[E0277]: the size for values of type `T` cannot be known at compilation time | ||
--> $DIR/bad-suggestionf-for-repeated-unsized-bound-127441.rs:12:29 | ||
| | ||
LL | fn foo2<T: ?Sized + ?Sized>(a: T) {} | ||
| - ^ doesn't have a size known at compile-time | ||
| | | ||
| this type parameter needs to be `Sized` | ||
| | ||
= help: unsized fn params are gated as an unstable feature | ||
help: consider removing the `?Sized` bound to make the type parameter `Sized` | ||
| | ||
LL - fn foo2<T: ?Sized + ?Sized>(a: T) {} | ||
LL + fn foo2<T>(a: T) {} | ||
| | ||
help: function arguments must have a statically known size, borrowed types always have a known size | ||
| | ||
LL | fn foo2<T: ?Sized + ?Sized>(a: &T) {} | ||
| + | ||
|
||
error[E0277]: the size for values of type `T` cannot be known at compilation time | ||
--> $DIR/bad-suggestionf-for-repeated-unsized-bound-127441.rs:16:37 | ||
| | ||
LL | fn foo3<T: ?Sized + ?Sized + Debug>(a: T) {} | ||
| - ^ doesn't have a size known at compile-time | ||
| | | ||
| this type parameter needs to be `Sized` | ||
| | ||
= help: unsized fn params are gated as an unstable feature | ||
help: consider restricting type parameters | ||
| | ||
LL - fn foo3<T: ?Sized + ?Sized + Debug>(a: T) {} | ||
LL + fn foo3<T: Debug>(a: T) {} | ||
| | ||
help: function arguments must have a statically known size, borrowed types always have a known size | ||
| | ||
LL | fn foo3<T: ?Sized + ?Sized + Debug>(a: &T) {} | ||
| + | ||
|
||
error[E0277]: the size for values of type `T` cannot be known at compilation time | ||
--> $DIR/bad-suggestionf-for-repeated-unsized-bound-127441.rs:20:38 | ||
| | ||
LL | fn foo4<T: ?Sized + Debug + ?Sized >(a: T) {} | ||
| - ^ doesn't have a size known at compile-time | ||
| | | ||
| this type parameter needs to be `Sized` | ||
| | ||
= help: unsized fn params are gated as an unstable feature | ||
help: consider restricting type parameters | ||
| | ||
LL - fn foo4<T: ?Sized + Debug + ?Sized >(a: T) {} | ||
LL + fn foo4<T: Debug >(a: T) {} | ||
| | ||
help: function arguments must have a statically known size, borrowed types always have a known size | ||
| | ||
LL | fn foo4<T: ?Sized + Debug + ?Sized >(a: &T) {} | ||
| + | ||
|
||
error[E0277]: the size for values of type `impl ?Sized` cannot be known at compilation time | ||
--> $DIR/bad-suggestionf-for-repeated-unsized-bound-127441.rs:24:9 | ||
| | ||
LL | fn foo5(_: impl ?Sized) {} | ||
| ^ ----------- this type parameter needs to be `Sized` | ||
| | | ||
| doesn't have a size known at compile-time | ||
| | ||
= help: unsized fn params are gated as an unstable feature | ||
help: consider replacing `?Sized` with `Sized` | ||
| | ||
LL - fn foo5(_: impl ?Sized) {} | ||
LL + fn foo5(_: impl Sized) {} | ||
| | ||
help: function arguments must have a statically known size, borrowed types always have a known size | ||
| | ||
LL | fn foo5(_: &impl ?Sized) {} | ||
| + | ||
|
||
error[E0277]: the size for values of type `impl ?Sized + ?Sized` cannot be known at compilation time | ||
--> $DIR/bad-suggestionf-for-repeated-unsized-bound-127441.rs:27:9 | ||
| | ||
LL | fn foo6(_: impl ?Sized + ?Sized) {} | ||
| ^ -------------------- this type parameter needs to be `Sized` | ||
| | | ||
| doesn't have a size known at compile-time | ||
| | ||
= help: unsized fn params are gated as an unstable feature | ||
help: consider restricting type parameters | ||
| | ||
LL - fn foo6(_: impl ?Sized + ?Sized) {} | ||
LL + fn foo6(_: impl Sized) {} | ||
| | ||
help: function arguments must have a statically known size, borrowed types always have a known size | ||
| | ||
LL | fn foo6(_: &impl ?Sized + ?Sized) {} | ||
| + | ||
|
||
error[E0277]: the size for values of type `impl ?Sized + ?Sized + Debug` cannot be known at compilation time | ||
--> $DIR/bad-suggestionf-for-repeated-unsized-bound-127441.rs:31:9 | ||
| | ||
LL | fn foo7(_: impl ?Sized + ?Sized + Debug) {} | ||
| ^ ---------------------------- this type parameter needs to be `Sized` | ||
| | | ||
| doesn't have a size known at compile-time | ||
| | ||
= help: unsized fn params are gated as an unstable feature | ||
help: consider restricting type parameters | ||
| | ||
LL - fn foo7(_: impl ?Sized + ?Sized + Debug) {} | ||
LL + fn foo7(_: impl Debug) {} | ||
| | ||
help: function arguments must have a statically known size, borrowed types always have a known size | ||
| | ||
LL | fn foo7(_: &impl ?Sized + ?Sized + Debug) {} | ||
| + | ||
|
||
error[E0277]: the size for values of type `impl ?Sized + Debug + ?Sized` cannot be known at compilation time | ||
--> $DIR/bad-suggestionf-for-repeated-unsized-bound-127441.rs:35:9 | ||
| | ||
LL | fn foo8(_: impl ?Sized + Debug + ?Sized ) {} | ||
| ^ ---------------------------- this type parameter needs to be `Sized` | ||
| | | ||
| doesn't have a size known at compile-time | ||
| | ||
= help: unsized fn params are gated as an unstable feature | ||
help: consider restricting type parameters | ||
| | ||
LL - fn foo8(_: impl ?Sized + Debug + ?Sized ) {} | ||
LL + fn foo8(_: impl Debug ) {} | ||
| | ||
help: function arguments must have a statically known size, borrowed types always have a known size | ||
| | ||
LL | fn foo8(_: &impl ?Sized + Debug + ?Sized ) {} | ||
| + | ||
|
||
error: aborting due to 14 previous errors | ||
|
||
Some errors have detailed explanations: E0203, E0277. | ||
For more information about an error, try `rustc --explain E0203`. |