@@ -253,28 +253,40 @@ impl<'tcx> RegionInferenceContext<'tcx> {
253
253
let outgoing_edges_from_graph = self . constraint_graph
254
254
. outgoing_edges ( r, & self . constraints , fr_static) ;
255
255
256
-
257
- // But member constraints can also give rise to `'r: 'x`
258
- // edges that were not part of the graph initially, so
259
- // watch out for those.
260
- let outgoing_edges_from_picks = self . applied_member_constraints ( r)
261
- . iter ( )
262
- . map ( |& AppliedMemberConstraint { min_choice, member_constraint_index, .. } | {
263
- let p_c = & self . member_constraints [ member_constraint_index] ;
264
- OutlivesConstraint {
265
- sup : r,
266
- sub : min_choice,
267
- locations : Locations :: All ( p_c. definition_span ) ,
268
- category : ConstraintCategory :: OpaqueType ,
256
+ macro_rules! handle_constraint {
257
+ ( $constraint: ident) => {
258
+ debug_assert_eq!( $constraint. sup, r) ;
259
+ let sub_region = $constraint. sub;
260
+ if let Trace :: NotVisited = context[ sub_region] {
261
+ context[ sub_region] = Trace :: FromOutlivesConstraint ( $constraint) ;
262
+ deque. push_back( sub_region) ;
269
263
}
270
- } ) ;
271
-
272
- for constraint in outgoing_edges_from_graph. chain ( outgoing_edges_from_picks) {
273
- debug_assert_eq ! ( constraint. sup, r) ;
274
- let sub_region = constraint. sub ;
275
- if let Trace :: NotVisited = context[ sub_region] {
276
- context[ sub_region] = Trace :: FromOutlivesConstraint ( constraint) ;
277
- deque. push_back ( sub_region) ;
264
+ }
265
+ }
266
+
267
+ for constraint in outgoing_edges_from_graph {
268
+ handle_constraint ! ( constraint) ;
269
+ }
270
+
271
+ // But member constraints can also give rise to `'r: 'x` edges that
272
+ // were not part of the graph initially, so watch out for those.
273
+ // (But they are extremely rare.)
274
+ let applied_member_constraints = self . applied_member_constraints ( r) ;
275
+ if !applied_member_constraints. is_empty ( ) {
276
+ let outgoing_edges_from_picks = self . applied_member_constraints ( r)
277
+ . iter ( )
278
+ . map ( |& AppliedMemberConstraint { min_choice, member_constraint_index, .. } | {
279
+ let p_c = & self . member_constraints [ member_constraint_index] ;
280
+ OutlivesConstraint {
281
+ sup : r,
282
+ sub : min_choice,
283
+ locations : Locations :: All ( p_c. definition_span ) ,
284
+ category : ConstraintCategory :: OpaqueType ,
285
+ }
286
+ } ) ;
287
+
288
+ for constraint in outgoing_edges_from_picks {
289
+ handle_constraint ! ( constraint) ;
278
290
}
279
291
}
280
292
}
0 commit comments