Rollup merge of #57981 - Zoxc:fix-57979, r=nikomatsakis
Fix #57730 cc https://github.com/rust-lang/rust/pull/57730 r? @cramertj
This commit is contained in:
commit
84e88da431
@ -616,7 +616,7 @@ impl<'a> Visitor<'a> for AstValidator<'a> {
|
||||
if let Some(ref type_) = data.output {
|
||||
// `-> Foo` syntax is essentially an associated type binding,
|
||||
// so it is also allowed to contain nested `impl Trait`.
|
||||
self.with_impl_trait(None, |this| visit::walk_ty(this, type_));
|
||||
self.with_impl_trait(None, |this| this.visit_ty(type_));
|
||||
}
|
||||
}
|
||||
}
|
||||
|
42
src/test/ui/issues/issue-57979.rs
Normal file
42
src/test/ui/issues/issue-57979.rs
Normal file
@ -0,0 +1,42 @@
|
||||
// Regression test for #57979. This situation is meant to be an error.
|
||||
// As noted in the issue thread, we decided to forbid nested impl
|
||||
// trait of this kind:
|
||||
//
|
||||
// ```rust
|
||||
// fn foo() -> impl Foo<impl Bar> { .. }
|
||||
// ```
|
||||
//
|
||||
// Basically there are two hidden variables here, let's call them `X`
|
||||
// and `Y`, and we must prove that:
|
||||
//
|
||||
// ```
|
||||
// X: Foo<Y>
|
||||
// Y: Bar
|
||||
// ```
|
||||
//
|
||||
// However, the user is only giving us the return type `X`. It's true
|
||||
// that in some cases, we can infer `Y` from `X`, because `X` only
|
||||
// implements `Foo` for one type (and indeed the compiler does
|
||||
// inference of this kind), but I do recall that we intended to forbid
|
||||
// this -- in part because such inference is fragile, and there is not
|
||||
// necessarily a way for the user to be more explicit should the
|
||||
// inference fail (so you could get stuck with no way to port your
|
||||
// code forward if, for example, more impls are added to an existing
|
||||
// type).
|
||||
//
|
||||
// The same seems to apply in this situation. Here there are three impl traits, so we have
|
||||
//
|
||||
// ```
|
||||
// X: IntoIterator<Item = Y>
|
||||
// Y: Borrow<Data<Z>>
|
||||
// Z: AsRef<[u8]>
|
||||
// ```
|
||||
|
||||
use std::borrow::Borrow;
|
||||
|
||||
pub struct Data<TBody>(TBody);
|
||||
|
||||
pub fn collect(_: impl IntoIterator<Item = impl Borrow<Data<impl AsRef<[u8]>>>>) {
|
||||
//~^ ERROR
|
||||
unimplemented!()
|
||||
}
|
17
src/test/ui/issues/issue-57979.stderr
Normal file
17
src/test/ui/issues/issue-57979.stderr
Normal file
@ -0,0 +1,17 @@
|
||||
error[E0666]: nested `impl Trait` is not allowed
|
||||
--> $DIR/issue-57979.rs:39:61
|
||||
|
|
||||
LL | pub fn collect(_: impl IntoIterator<Item = impl Borrow<Data<impl AsRef<[u8]>>>>) {
|
||||
| -----------------^^^^^^^^^^^^^^^^--
|
||||
| | |
|
||||
| | nested `impl Trait` here
|
||||
| outer `impl Trait`
|
||||
|
||||
error[E0601]: `main` function not found in crate `issue_57979`
|
||||
|
|
||||
= note: consider adding a `main` function to `$DIR/issue-57979.rs`
|
||||
|
||||
error: aborting due to 2 previous errors
|
||||
|
||||
Some errors occurred: E0601, E0666.
|
||||
For more information about an error, try `rustc --explain E0601`.
|
Loading…
x
Reference in New Issue
Block a user