forked from rust-lang/rust
-
Notifications
You must be signed in to change notification settings - Fork 6
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 rust-lang#120507 - estebank:issue-108428, r=davidtwco Account for non-overlapping unmet trait bounds in suggestion When a method not found on a type parameter could have been provided by any of multiple traits, suggest each trait individually, instead of a single suggestion to restrict the type parameter with *all* of them. Before: ``` error[E0599]: the method `cmp` exists for reference `&T`, but its trait bounds were not satisfied --> $DIR/method-on-unbounded-type-param.rs:5:10 | LL | (&a).cmp(&b) | ^^^ method cannot be called on `&T` due to unsatisfied trait bounds | = note: the following trait bounds were not satisfied: `T: Ord` which is required by `&T: Ord` `&T: Iterator` which is required by `&mut &T: Iterator` `T: Iterator` which is required by `&mut T: Iterator` help: consider restricting the type parameters to satisfy the trait bounds | LL | fn g<T>(a: T, b: T) -> std::cmp::Ordering where T: Iterator, T: Ord { | +++++++++++++++++++++++++ ``` After: ``` error[E0599]: the method `cmp` exists for reference `&T`, but its trait bounds were not satisfied --> $DIR/method-on-unbounded-type-param.rs:5:10 | LL | (&a).cmp(&b) | ^^^ method cannot be called on `&T` due to unsatisfied trait bounds | = note: the following trait bounds were not satisfied: `T: Ord` which is required by `&T: Ord` `&T: Iterator` which is required by `&mut &T: Iterator` `T: Iterator` which is required by `&mut T: Iterator` = help: items from traits can only be used if the type parameter is bounded by the trait help: the following traits define an item `cmp`, perhaps you need to restrict type parameter `T` with one of them: | LL | fn g<T: Ord>(a: T, b: T) -> std::cmp::Ordering { | +++++ LL | fn g<T: Iterator>(a: T, b: T) -> std::cmp::Ordering { | ++++++++++ ``` Fix rust-lang#108428. Follow up to rust-lang#120396, only last commit is relevant.
- Loading branch information
Showing
10 changed files
with
158 additions
and
46 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
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
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 |
---|---|---|
|
@@ -5,7 +5,7 @@ trait X { | |
type Y<T>; | ||
} | ||
|
||
trait M { | ||
trait M { //~ NOTE | ||
fn f(&self) {} | ||
} | ||
|
||
|
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
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -15,6 +15,12 @@ note: the following trait bounds were not satisfied: | |
| | ||
LL | impl<T> StreamExt for T where for<'a> &'a mut T: Stream {} | ||
| --------- - ^^^^^^ unsatisfied trait bound introduced here | ||
= help: items from traits can only be used if the trait is implemented and in scope | ||
note: `StreamExt` defines an item `filterx`, perhaps you need to implement it | ||
--> $DIR/issue-30786.rs:66:1 | ||
| | ||
LL | pub trait StreamExt | ||
| ^^^^^^^^^^^^^^^^^^^ | ||
|
||
error[E0599]: the method `countx` exists for struct `Filter<Map<Repeat, fn(&u64) -> &u64 {identity::<u64>}>, {[email protected]:131:30}>`, but its trait bounds were not satisfied | ||
--> $DIR/issue-30786.rs:132:24 | ||
|
@@ -33,6 +39,12 @@ note: the following trait bounds were not satisfied: | |
| | ||
LL | impl<T> StreamExt for T where for<'a> &'a mut T: Stream {} | ||
| --------- - ^^^^^^ unsatisfied trait bound introduced here | ||
= help: items from traits can only be used if the trait is implemented and in scope | ||
note: `StreamExt` defines an item `countx`, perhaps you need to implement it | ||
--> $DIR/issue-30786.rs:66:1 | ||
| | ||
LL | pub trait StreamExt | ||
| ^^^^^^^^^^^^^^^^^^^ | ||
|
||
error: aborting due to 2 previous errors | ||
|
||
|
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
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,15 @@ | ||
fn f<T>(a: T, b: T) -> std::cmp::Ordering { | ||
a.cmp(&b) //~ ERROR E0599 | ||
} | ||
fn g<T>(a: T, b: T) -> std::cmp::Ordering { | ||
(&a).cmp(&b) //~ ERROR E0599 | ||
} | ||
fn h<T>(a: &T, b: T) -> std::cmp::Ordering { | ||
a.cmp(&b) //~ ERROR E0599 | ||
} | ||
trait T {} | ||
impl<X: std::cmp::Ord> T for X {} | ||
fn main() { | ||
let x: Box<dyn T> = Box::new(0); | ||
x.cmp(&x); //~ ERROR E0599 | ||
} |
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,84 @@ | ||
error[E0599]: no method named `cmp` found for type parameter `T` in the current scope | ||
--> $DIR/method-on-unbounded-type-param.rs:2:7 | ||
| | ||
LL | fn f<T>(a: T, b: T) -> std::cmp::Ordering { | ||
| - method `cmp` not found for this type parameter | ||
LL | a.cmp(&b) | ||
| ^^^ method cannot be called on `T` due to unsatisfied trait bounds | ||
| | ||
= help: items from traits can only be used if the type parameter is bounded by the trait | ||
help: the following traits define an item `cmp`, perhaps you need to restrict type parameter `T` with one of them: | ||
| | ||
LL | fn f<T: Ord>(a: T, b: T) -> std::cmp::Ordering { | ||
| +++++ | ||
LL | fn f<T: Iterator>(a: T, b: T) -> std::cmp::Ordering { | ||
| ++++++++++ | ||
|
||
error[E0599]: the method `cmp` exists for reference `&T`, but its trait bounds were not satisfied | ||
--> $DIR/method-on-unbounded-type-param.rs:5:10 | ||
| | ||
LL | (&a).cmp(&b) | ||
| ^^^ method cannot be called on `&T` due to unsatisfied trait bounds | ||
| | ||
= note: the following trait bounds were not satisfied: | ||
`T: Ord` | ||
which is required by `&T: Ord` | ||
`&T: Iterator` | ||
which is required by `&mut &T: Iterator` | ||
`T: Iterator` | ||
which is required by `&mut T: Iterator` | ||
= help: items from traits can only be used if the type parameter is bounded by the trait | ||
help: the following traits define an item `cmp`, perhaps you need to restrict type parameter `T` with one of them: | ||
| | ||
LL | fn g<T: Ord>(a: T, b: T) -> std::cmp::Ordering { | ||
| +++++ | ||
LL | fn g<T: Iterator>(a: T, b: T) -> std::cmp::Ordering { | ||
| ++++++++++ | ||
|
||
error[E0599]: the method `cmp` exists for reference `&T`, but its trait bounds were not satisfied | ||
--> $DIR/method-on-unbounded-type-param.rs:8:7 | ||
| | ||
LL | a.cmp(&b) | ||
| ^^^ method cannot be called on `&T` due to unsatisfied trait bounds | ||
| | ||
= note: the following trait bounds were not satisfied: | ||
`T: Ord` | ||
which is required by `&T: Ord` | ||
`&T: Iterator` | ||
which is required by `&mut &T: Iterator` | ||
`T: Iterator` | ||
which is required by `&mut T: Iterator` | ||
= help: items from traits can only be used if the type parameter is bounded by the trait | ||
help: the following traits define an item `cmp`, perhaps you need to restrict type parameter `T` with one of them: | ||
| | ||
LL | fn h<T: Ord>(a: &T, b: T) -> std::cmp::Ordering { | ||
| +++++ | ||
LL | fn h<T: Iterator>(a: &T, b: T) -> std::cmp::Ordering { | ||
| ++++++++++ | ||
|
||
error[E0599]: the method `cmp` exists for struct `Box<dyn T>`, but its trait bounds were not satisfied | ||
--> $DIR/method-on-unbounded-type-param.rs:14:7 | ||
| | ||
LL | trait T {} | ||
| ------- doesn't satisfy `dyn T: Iterator` or `dyn T: Ord` | ||
... | ||
LL | x.cmp(&x); | ||
| ^^^ method cannot be called on `Box<dyn T>` due to unsatisfied trait bounds | ||
| | ||
= note: the following trait bounds were not satisfied: | ||
`dyn T: Iterator` | ||
which is required by `Box<dyn T>: Iterator` | ||
`dyn T: Ord` | ||
which is required by `Box<dyn T>: Ord` | ||
`Box<dyn T>: Iterator` | ||
which is required by `&mut Box<dyn T>: Iterator` | ||
`dyn T: Iterator` | ||
which is required by `&mut dyn T: Iterator` | ||
= help: items from traits can only be used if the trait is implemented and in scope | ||
= note: the following traits define an item `cmp`, perhaps you need to implement one of them: | ||
candidate #1: `Ord` | ||
candidate #2: `Iterator` | ||
|
||
error: aborting due to 4 previous errors | ||
|
||
For more information about this error, try `rustc --explain E0599`. |