Rollup merge of #107803 - eggyal:do_not_bring_trait_alias_supertraits_into_scope, r=compiler-errors

Do not bring trait alias supertraits into scope

Fixes #107747
cc #41517
This commit is contained in:
Dylan DPC 2023-02-09 23:18:36 +05:30 committed by GitHub
commit 16a4138387
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
2 changed files with 52 additions and 17 deletions

View File

@ -951,14 +951,26 @@ fn assemble_extension_candidates_for_trait(
let trait_ref = self.tcx.mk_trait_ref(trait_def_id, trait_substs); let trait_ref = self.tcx.mk_trait_ref(trait_def_id, trait_substs);
if self.tcx.is_trait_alias(trait_def_id) { if self.tcx.is_trait_alias(trait_def_id) {
// For trait aliases, assume all supertraits are relevant. // For trait aliases, recursively assume all explicitly named traits are relevant
let bounds = iter::once(ty::Binder::dummy(trait_ref)); for expansion in traits::expand_trait_aliases(
self.elaborate_bounds(bounds, |this, new_trait_ref, item| { self.tcx,
let new_trait_ref = this.erase_late_bound_regions(new_trait_ref); iter::once((ty::Binder::dummy(trait_ref), self.span)),
) {
let bound_trait_ref = expansion.trait_ref();
for item in self.impl_or_trait_item(bound_trait_ref.def_id()) {
if !self.has_applicable_self(&item) {
self.record_static_candidate(CandidateSource::Trait(
bound_trait_ref.def_id(),
));
} else {
let new_trait_ref = self.erase_late_bound_regions(bound_trait_ref);
let (xform_self_ty, xform_ret_ty) = let (xform_self_ty, xform_ret_ty) = self.xform_self_ty(
this.xform_self_ty(&item, new_trait_ref.self_ty(), new_trait_ref.substs); &item,
this.push_candidate( new_trait_ref.self_ty(),
new_trait_ref.substs,
);
self.push_candidate(
Candidate { Candidate {
xform_self_ty, xform_self_ty,
xform_ret_ty, xform_ret_ty,
@ -968,7 +980,9 @@ fn assemble_extension_candidates_for_trait(
}, },
false, false,
); );
}); }
}
}
} else { } else {
debug_assert!(self.tcx.is_trait(trait_def_id)); debug_assert!(self.tcx.is_trait(trait_def_id));
if self.tcx.trait_is_auto(trait_def_id) { if self.tcx.trait_is_auto(trait_def_id) {

View File

@ -0,0 +1,21 @@
// Regression test for #107747: methods from trait alias supertraits were brought into scope
//
// check-pass
#![feature(trait_alias)]
use std::fmt;
trait Foo: fmt::Debug {}
trait Bar = Foo;
#[derive(Debug)]
struct Qux(bool);
impl fmt::Display for Qux {
fn fmt(&self, f: &mut fmt::Formatter<'_>) -> fmt::Result {
self.0.fmt(f)
}
}
fn main() {}