Add projection obligations when comparing impl too
This commit is contained in:
parent
5c6a7e71cd
commit
31032ecb15
2 changed files with 40 additions and 1 deletions
|
@ -342,9 +342,16 @@ fn compare_method_predicate_entailment<'tcx>(
|
||||||
continue;
|
continue;
|
||||||
};
|
};
|
||||||
for obligation in obligations {
|
for obligation in obligations {
|
||||||
|
debug!(?obligation);
|
||||||
match obligation.predicate.kind().skip_binder() {
|
match obligation.predicate.kind().skip_binder() {
|
||||||
|
// We need to register Projection oblgiations too, because we may end up with
|
||||||
|
// an implied `X::Item: 'a`, which gets desugared into `X::Item = ?0`, `?0: 'a`.
|
||||||
|
// If we only register the region outlives obligation, this leads to an unconstrained var.
|
||||||
|
// See `implied_bounds_entailment_alias_var` test.
|
||||||
ty::PredicateKind::Clause(
|
ty::PredicateKind::Clause(
|
||||||
ty::ClauseKind::RegionOutlives(..) | ty::ClauseKind::TypeOutlives(..),
|
ty::ClauseKind::RegionOutlives(..)
|
||||||
|
| ty::ClauseKind::TypeOutlives(..)
|
||||||
|
| ty::ClauseKind::Projection(..),
|
||||||
) => ocx.register_obligation(obligation),
|
) => ocx.register_obligation(obligation),
|
||||||
ty::PredicateKind::Clause(ty::ClauseKind::WellFormed(arg)) => {
|
ty::PredicateKind::Clause(ty::ClauseKind::WellFormed(arg)) => {
|
||||||
if wf_args_seen.insert(arg) {
|
if wf_args_seen.insert(arg) {
|
||||||
|
|
|
@ -0,0 +1,32 @@
|
||||||
|
// check-pass
|
||||||
|
|
||||||
|
trait Data {
|
||||||
|
type Elem;
|
||||||
|
}
|
||||||
|
|
||||||
|
impl<F, S: Data<Elem = F>> Data for ArrayBase<S> {
|
||||||
|
type Elem = F;
|
||||||
|
}
|
||||||
|
|
||||||
|
struct DatasetIter<'a, R: Data> {
|
||||||
|
data: &'a R::Elem,
|
||||||
|
}
|
||||||
|
|
||||||
|
pub struct ArrayBase<S> {
|
||||||
|
data: S,
|
||||||
|
}
|
||||||
|
|
||||||
|
trait Trait {
|
||||||
|
type Item;
|
||||||
|
fn next() -> Option<Self::Item>;
|
||||||
|
}
|
||||||
|
|
||||||
|
impl<'a, D: Data> Trait for DatasetIter<'a, ArrayBase<D>> {
|
||||||
|
type Item = ();
|
||||||
|
|
||||||
|
fn next() -> Option<Self::Item> {
|
||||||
|
None
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
fn main() {}
|
Loading…
Add table
Reference in a new issue