@@ -217,9 +217,9 @@ fn ensure_drop_predicates_are_implied_by_item_defn<'tcx>(
217
217
// repeated `.iter().any(..)` calls.
218
218
219
219
// This closure is a more robust way to check `Predicate` equality
220
- // than simple `==` checks (which were the previous implementation). It relies on
221
- // `ty::relate` for `TraitPredicate`, `ProjectionPredicate`, `ConstEvaluatable`
222
- // `TypeOutlives ` and `TypeWellFormedFromEnv ` (which implement the Relate trait),
220
+ // than simple `==` checks (which were the previous implementation).
221
+ // It relies on `ty::relate` for `TraitPredicate`, `ProjectionPredicate`,
222
+ // `ConstEvaluatable ` and `TypeOutlives ` (which implement the Relate trait),
223
223
// while delegating on simple equality for the other `Predicate`.
224
224
// This implementation solves (Issue #59497) and (Issue #58311).
225
225
// It is unclear to me at the moment whether the approach based on `relate`
@@ -242,10 +242,6 @@ fn ensure_drop_predicates_are_implied_by_item_defn<'tcx>(
242
242
( ty:: PredicateKind :: TypeOutlives ( a) , ty:: PredicateKind :: TypeOutlives ( b) ) => {
243
243
relator. relate ( predicate. rebind ( a. 0 ) , p. rebind ( b. 0 ) ) . is_ok ( )
244
244
}
245
- (
246
- ty:: PredicateKind :: TypeWellFormedFromEnv ( a) ,
247
- ty:: PredicateKind :: TypeWellFormedFromEnv ( b) ,
248
- ) => relator. relate ( predicate. rebind ( a) , p. rebind ( b) ) . is_ok ( ) ,
249
245
_ => predicate == p,
250
246
}
251
247
} ;
0 commit comments