|  | #![allow(unused_assignments)] | 
|  | //@ failure-status: 1 | 
|  |  | 
|  | #[rustfmt::skip] | 
|  | fn main() -> Result<(), u8> { | 
|  | let mut countdown = 10; | 
|  | while | 
|  | countdown | 
|  | > | 
|  | 0 | 
|  | { | 
|  | if | 
|  | countdown | 
|  | < | 
|  | 5 | 
|  | { | 
|  | return | 
|  | if | 
|  | countdown | 
|  | > | 
|  | 8 | 
|  | { | 
|  | Ok(()) | 
|  | } | 
|  | else | 
|  | { | 
|  | Err(1) | 
|  | } | 
|  | ; | 
|  | } | 
|  | countdown | 
|  | -= | 
|  | 1 | 
|  | ; | 
|  | } | 
|  | Ok(()) | 
|  | } | 
|  |  | 
|  | // ISSUE(77553): Originally, this test had `Err(1)` on line 22 (instead of `Ok(())`) and | 
|  | // `std::process::exit(2)` on line 26 (instead of `Err(1)`); and this worked as expected on Linux | 
|  | // and MacOS. But on Windows (MSVC, at least), the call to `std::process::exit()` exits the program | 
|  | // without saving the InstrProf coverage counters. The use of `std::process:exit()` is not critical | 
|  | // to the coverage test for early returns, but this is a limitation that should be fixed. |