2024-04-11 08:15:34 -05:00
|
|
|
#![feature(coroutines, coroutine_trait, stmt_expr_attributes)]
|
2021-05-01 16:56:48 -05:00
|
|
|
|
2023-10-19 11:06:43 -05:00
|
|
|
use std::ops::{Coroutine, CoroutineState};
|
2021-05-01 16:56:48 -05:00
|
|
|
use std::pin::Pin;
|
|
|
|
|
|
|
|
// The following implementation of a function called from a `yield` statement
|
|
|
|
// (apparently requiring the Result and the `String` type or constructor)
|
2023-10-19 16:46:28 -05:00
|
|
|
// creates conditions where the `coroutine::StateTransform` MIR transform will
|
2021-05-01 16:56:48 -05:00
|
|
|
// drop all `Counter` `Coverage` statements from a MIR. `simplify.rs` has logic
|
|
|
|
// to handle this condition, and still report dead block coverage.
|
|
|
|
fn get_u32(val: bool) -> Result<u32, String> {
|
2024-01-15 20:52:08 -06:00
|
|
|
if val {
|
2024-05-28 23:06:53 -05:00
|
|
|
Ok(1) //
|
2024-01-15 20:52:08 -06:00
|
|
|
} else {
|
2024-05-28 23:06:53 -05:00
|
|
|
Err(String::from("some error")) //
|
2024-01-15 20:52:08 -06:00
|
|
|
}
|
2021-05-01 16:56:48 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
fn main() {
|
|
|
|
let is_true = std::env::args().len() == 1;
|
2024-05-28 23:27:57 -05:00
|
|
|
let mut coroutine = #[coroutine]
|
|
|
|
|| {
|
2021-05-01 16:56:48 -05:00
|
|
|
yield get_u32(is_true);
|
|
|
|
return "foo";
|
|
|
|
};
|
|
|
|
|
2023-10-19 16:46:28 -05:00
|
|
|
match Pin::new(&mut coroutine).resume(()) {
|
2023-10-19 11:06:43 -05:00
|
|
|
CoroutineState::Yielded(Ok(1)) => {}
|
2021-05-01 16:56:48 -05:00
|
|
|
_ => panic!("unexpected return from resume"),
|
|
|
|
}
|
2023-10-19 16:46:28 -05:00
|
|
|
match Pin::new(&mut coroutine).resume(()) {
|
2023-10-19 11:06:43 -05:00
|
|
|
CoroutineState::Complete("foo") => {}
|
2021-05-01 16:56:48 -05:00
|
|
|
_ => panic!("unexpected return from resume"),
|
|
|
|
}
|
|
|
|
}
|