forked from rust-lang/rust
-
Notifications
You must be signed in to change notification settings - Fork 0
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#132760 - dianne:iter-into-iter, r=lcnr
Don't suggest `.into_iter()` on iterators This makes the the suggestion to call `.into_iter()` only consider unsatisfied `Iterator` bounds for the receiver type itself. That way, it ignores predicates generated by trying to auto-ref the receiver (the result of which usually won't implement `Iterator`). Fixes rust-lang#127511 Unfortunately, the error in that case is still confusing: it labels `Iterator` as an unsatisfied bound because `&impl Iterator: Iterator` can't be satisfied, despite that not being required or helpful. I'd like to handle that in a separate PR. ~~I'm hoping fixing rust-lang#124802 will fix it too.~~ It doesn't look connected to that issue. Still, I think it'd be clearest to visually distinguish unsatisfied predicates from different attempts at `pick_method`; I'll make a PR for that soon.
- Loading branch information
Showing
3 changed files
with
56 additions
and
8 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
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,18 @@ | ||
//! regression test for #127511: don't suggest `.into_iter()` on iterators | ||
trait Missing {} | ||
trait HasMethod { | ||
fn foo(self); | ||
} | ||
impl<T: Iterator + Missing> HasMethod for T { | ||
fn foo(self) {} | ||
} | ||
|
||
fn get_iter() -> impl Iterator { | ||
core::iter::once(()) | ||
} | ||
|
||
fn main() { | ||
get_iter().foo(); | ||
//~^ ERROR the method `foo` exists for opaque type `impl Iterator`, but its trait bounds were not satisfied [E0599] | ||
} |
28 changes: 28 additions & 0 deletions
28
tests/ui/iterators/iterator-does-not-need-into-iter.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,28 @@ | ||
error[E0599]: the method `foo` exists for opaque type `impl Iterator`, but its trait bounds were not satisfied | ||
--> $DIR/iterator-does-not-need-into-iter.rs:16:16 | ||
| | ||
LL | get_iter().foo(); | ||
| ^^^ method cannot be called on `impl Iterator` due to unsatisfied trait bounds | ||
| | ||
note: the following trait bounds were not satisfied: | ||
`&impl Iterator: Iterator` | ||
`&impl Iterator: Missing` | ||
`&mut impl Iterator: Missing` | ||
`impl Iterator: Missing` | ||
--> $DIR/iterator-does-not-need-into-iter.rs:7:9 | ||
| | ||
LL | impl<T: Iterator + Missing> HasMethod for T { | ||
| ^^^^^^^^ ^^^^^^^ --------- - | ||
| | | | ||
| | unsatisfied trait bound introduced here | ||
| unsatisfied trait bound introduced here | ||
= help: items from traits can only be used if the trait is implemented and in scope | ||
note: `HasMethod` defines an item `foo`, perhaps you need to implement it | ||
--> $DIR/iterator-does-not-need-into-iter.rs:4:1 | ||
| | ||
LL | trait HasMethod { | ||
| ^^^^^^^^^^^^^^^ | ||
|
||
error: aborting due to 1 previous error | ||
|
||
For more information about this error, try `rustc --explain E0599`. |