@@ -315,7 +315,7 @@ impl<'a> CoverageSpansGenerator<'a> {
315
315
debug ! (
316
316
" curr overlaps a closure (prev). Drop curr and keep prev for next iter. prev={prev:?}" ,
317
317
) ;
318
- self . take_curr ( ) ;
318
+ self . take_curr ( ) ; // Discards curr.
319
319
} else if curr. is_closure {
320
320
self . carve_out_span_for_closure ( ) ;
321
321
} else if self . prev_original_span == curr. span {
@@ -341,7 +341,7 @@ impl<'a> CoverageSpansGenerator<'a> {
341
341
as prev, but is in a different bcb. Drop curr and keep prev for next iter. \
342
342
prev={prev:?}",
343
343
) ;
344
- self . take_curr ( ) ;
344
+ self . take_curr ( ) ; // Discards curr.
345
345
} else {
346
346
self . hold_pending_dups_unless_dominated ( ) ;
347
347
}
@@ -431,6 +431,12 @@ impl<'a> CoverageSpansGenerator<'a> {
431
431
. unwrap_or_else ( || bug ! ( "invalid attempt to unwrap a None some_curr" ) )
432
432
}
433
433
434
+ /// If called, then the next call to `next_coverage_span()` will *not* update `prev` with the
435
+ /// `curr` coverage span.
436
+ fn take_curr ( & mut self ) -> CoverageSpan {
437
+ self . some_curr . take ( ) . unwrap_or_else ( || bug ! ( "invalid attempt to unwrap a None some_curr" ) )
438
+ }
439
+
434
440
fn prev ( & self ) -> & CoverageSpan {
435
441
self . some_prev
436
442
. as_ref ( )
@@ -502,12 +508,6 @@ impl<'a> CoverageSpansGenerator<'a> {
502
508
false
503
509
}
504
510
505
- /// If called, then the next call to `next_coverage_span()` will *not* update `prev` with the
506
- /// `curr` coverage span.
507
- fn take_curr ( & mut self ) -> CoverageSpan {
508
- self . some_curr . take ( ) . unwrap_or_else ( || bug ! ( "invalid attempt to unwrap a None some_curr" ) )
509
- }
510
-
511
511
/// Returns true if the curr span should be skipped because prev has already advanced beyond the
512
512
/// end of curr. This can only happen if a prior iteration updated `prev` to skip past a region
513
513
/// of code, such as skipping past a closure.
@@ -554,7 +554,7 @@ impl<'a> CoverageSpansGenerator<'a> {
554
554
dup. span = dup. span . with_lo ( right_cutoff) ;
555
555
}
556
556
self . pending_dups . append ( & mut pending_dups) ;
557
- let closure_covspan = self . take_curr ( ) ;
557
+ let closure_covspan = self . take_curr ( ) ; // Prevent this curr from becoming prev.
558
558
self . push_refined_span ( closure_covspan) ; // since self.prev() was already updated
559
559
} else {
560
560
pending_dups. clear ( ) ;
0 commit comments