Rollup merge of #112868 - compiler-errors:liberate-afit-sugg, r=WaffleLapkin

Liberate bound vars properly when suggesting missing async-fn-in-trait

Fixes #112848
This commit is contained in:
Guillaume Gomez 2023-06-21 20:00:50 +02:00 committed by GitHub
commit 5ed75a9628
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
4 changed files with 22 additions and 17 deletions

View File

@ -470,19 +470,16 @@ fn suggestion_signature<'tcx>(
); );
match assoc.kind { match assoc.kind {
ty::AssocKind::Fn => { ty::AssocKind::Fn => fn_sig_suggestion(
// We skip the binder here because the binder would deanonymize all
// late-bound regions, and we don't want method signatures to show up
// `as for<'r> fn(&'r MyType)`. Pretty-printing handles late-bound
// regions just fine, showing `fn(&MyType)`.
fn_sig_suggestion(
tcx, tcx,
tcx.fn_sig(assoc.def_id).subst(tcx, substs).skip_binder(), tcx.liberate_late_bound_regions(
assoc.def_id,
tcx.fn_sig(assoc.def_id).subst(tcx, substs),
),
assoc.ident(tcx), assoc.ident(tcx),
tcx.predicates_of(assoc.def_id).instantiate_own(tcx, substs), tcx.predicates_of(assoc.def_id).instantiate_own(tcx, substs),
assoc, assoc,
) ),
}
ty::AssocKind::Type => { ty::AssocKind::Type => {
let (generics, where_clauses) = bounds_from_generic_predicates( let (generics, where_clauses) = bounds_from_generic_predicates(
tcx, tcx,

View File

@ -9,11 +9,14 @@ trait Trait {
async fn bar() -> i32; async fn bar() -> i32;
fn test(&self) -> impl Sized + '_; fn test(&self) -> impl Sized + '_;
async fn baz(&self) -> &i32;
} }
struct S; struct S;
impl Trait for S {fn test(&self) -> impl Sized + '_ { todo!() } impl Trait for S {async fn baz(&self) -> &i32 { todo!() }
fn test(&self) -> impl Sized + '_ { todo!() }
async fn bar() -> i32 { todo!() } async fn bar() -> i32 { todo!() }
async fn foo() { todo!() } async fn foo() { todo!() }
} }

View File

@ -9,6 +9,8 @@ trait Trait {
async fn bar() -> i32; async fn bar() -> i32;
fn test(&self) -> impl Sized + '_; fn test(&self) -> impl Sized + '_;
async fn baz(&self) -> &i32;
} }
struct S; struct S;

View File

@ -1,5 +1,5 @@
error[E0046]: not all trait items implemented, missing: `foo`, `bar`, `test` error[E0046]: not all trait items implemented, missing: `foo`, `bar`, `test`, `baz`
--> $DIR/suggest-missing-item.rs:16:1 --> $DIR/suggest-missing-item.rs:18:1
| |
LL | async fn foo(); LL | async fn foo();
| --------------- `foo` from trait | --------------- `foo` from trait
@ -9,9 +9,12 @@ LL | async fn bar() -> i32;
LL | LL |
LL | fn test(&self) -> impl Sized + '_; LL | fn test(&self) -> impl Sized + '_;
| ---------------------------------- `test` from trait | ---------------------------------- `test` from trait
LL |
LL | async fn baz(&self) -> &i32;
| ---------------------------- `baz` from trait
... ...
LL | impl Trait for S {} LL | impl Trait for S {}
| ^^^^^^^^^^^^^^^^ missing `foo`, `bar`, `test` in implementation | ^^^^^^^^^^^^^^^^ missing `foo`, `bar`, `test`, `baz` in implementation
error: aborting due to previous error error: aborting due to previous error