Normalize super trait bounds when confirming object candidates
This commit is contained in:
parent
d08ab945de
commit
e674cf0200
@ -440,15 +440,26 @@ impl<'cx, 'tcx> SelectionContext<'cx, 'tcx> {
|
|||||||
let upcast_trait_ref = upcast_trait_ref.unwrap();
|
let upcast_trait_ref = upcast_trait_ref.unwrap();
|
||||||
|
|
||||||
// Check supertraits hold
|
// Check supertraits hold
|
||||||
nested.extend(
|
for super_trait in tcx
|
||||||
tcx.super_predicates_of(trait_predicate.def_id())
|
.super_predicates_of(trait_predicate.def_id())
|
||||||
.instantiate(tcx, trait_predicate.trait_ref.substs)
|
.instantiate(tcx, trait_predicate.trait_ref.substs)
|
||||||
.predicates
|
.predicates
|
||||||
.into_iter()
|
.into_iter()
|
||||||
.map(|super_trait| {
|
{
|
||||||
Obligation::new(obligation.cause.clone(), obligation.param_env, super_trait)
|
let normalized_super_trait = normalize_with_depth_to(
|
||||||
}),
|
self,
|
||||||
);
|
obligation.param_env,
|
||||||
|
obligation.cause.clone(),
|
||||||
|
obligation.recursion_depth + 1,
|
||||||
|
&super_trait,
|
||||||
|
&mut nested,
|
||||||
|
);
|
||||||
|
nested.push(Obligation::new(
|
||||||
|
obligation.cause.clone(),
|
||||||
|
obligation.param_env.clone(),
|
||||||
|
normalized_super_trait,
|
||||||
|
));
|
||||||
|
}
|
||||||
|
|
||||||
let assoc_types: Vec<_> = tcx
|
let assoc_types: Vec<_> = tcx
|
||||||
.associated_items(trait_predicate.def_id())
|
.associated_items(trait_predicate.def_id())
|
||||||
|
26
src/test/ui/associated-types/object-normalization.rs
Normal file
26
src/test/ui/associated-types/object-normalization.rs
Normal file
@ -0,0 +1,26 @@
|
|||||||
|
// ignore-tidy-linelength
|
||||||
|
|
||||||
|
// Check that we normalize super predicates for object candidates.
|
||||||
|
|
||||||
|
// check-pass
|
||||||
|
|
||||||
|
use std::ops::Index;
|
||||||
|
|
||||||
|
fn next<'a, T>(s: &'a mut dyn SVec<Item = T, Output = T>) {
|
||||||
|
// To prove
|
||||||
|
// `dyn SVec<Item = T, Output = T>: SVec`
|
||||||
|
// we need to show
|
||||||
|
// `dyn SVec<Item = T, Output = T> as Index>::Output == <dyn SVec<Item = T, Output = T> as SVec>::Item`
|
||||||
|
// which, with the current normalization strategy, has to be eagerly
|
||||||
|
// normalized to:
|
||||||
|
// `dyn SVec<Item = T, Output = T> as Index>::Output == T`.
|
||||||
|
let _ = s.len();
|
||||||
|
}
|
||||||
|
|
||||||
|
trait SVec: Index<usize, Output = <Self as SVec>::Item> {
|
||||||
|
type Item;
|
||||||
|
|
||||||
|
fn len(&self) -> usize;
|
||||||
|
}
|
||||||
|
|
||||||
|
fn main() {}
|
Loading…
x
Reference in New Issue
Block a user