LL| |#![feature(coverage_attribute)] LL| |#![feature(noop_waker)] LL| |// edition: 2018 LL| | LL| |macro_rules! bail { LL| | ($msg:literal $(,)?) => { LL| | if $msg.len() > 0 { LL| | println!("no msg"); LL| | } else { LL| | println!($msg); LL| | } LL| | return Err(String::from($msg)); LL| | }; LL| |} LL| | LL| |macro_rules! on_error { LL| | ($value:expr, $error_message:expr) => { LL| 0| $value.or_else(|e| { LL| 0| // This closure, which is declared in a macro, should be instrumented. LL| 0| let message = format!($error_message, e); LL| 0| if message.len() > 0 { LL| 0| println!("{}", message); LL| 0| Ok(String::from("ok")) LL| | } else { LL| 0| bail!("error"); LL| | } LL| 0| }) LL| | }; LL| |} LL| | LL| 1|fn load_configuration_files() -> Result { LL| 1| Ok(String::from("config")) LL| 1|} LL| | LL| 1|pub async fn test() -> Result<(), String> { LL| 1| println!("Starting service"); LL| 1| let config = on_error!(load_configuration_files(), "Error loading configs: {}")?; ^0 LL| | LL| 1| let startup_delay_duration = String::from("arg"); LL| 1| let _ = (config, startup_delay_duration); LL| 1| Ok(()) LL| 1|} LL| | LL| |#[coverage(off)] LL| |fn main() { LL| | executor::block_on(test()).unwrap(); LL| |} LL| | LL| |mod executor { LL| | use core::future::Future; LL| | use core::pin::pin; LL| | use core::task::{Context, Poll, Waker}; LL| | LL| | #[coverage(off)] LL| | pub fn block_on(mut future: F) -> F::Output { LL| | let mut future = pin!(future); LL| | let mut context = Context::from_waker(Waker::noop()); LL| | LL| | loop { LL| | if let Poll::Ready(val) = future.as_mut().poll(&mut context) { LL| | break val; LL| | } LL| | } LL| | } LL| |}