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;
|
||||
};
|
||||
for obligation in obligations {
|
||||
debug!(?obligation);
|
||||
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::ClauseKind::RegionOutlives(..) | ty::ClauseKind::TypeOutlives(..),
|
||||
ty::ClauseKind::RegionOutlives(..)
|
||||
| ty::ClauseKind::TypeOutlives(..)
|
||||
| ty::ClauseKind::Projection(..),
|
||||
) => ocx.register_obligation(obligation),
|
||||
ty::PredicateKind::Clause(ty::ClauseKind::WellFormed(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