2023-09-05 23:42:57 +01:00
|
|
|
LL| |#![feature(coverage_attribute)]
|
2023-12-15 16:38:27 +11:00
|
|
|
LL| |#![feature(noop_waker)]
|
|
|
|
LL| |//@ edition: 2018
|
2023-08-16 12:42:33 +10:00
|
|
|
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) => {
|
2024-01-22 12:49:58 +11:00
|
|
|
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"))
|
2023-08-16 12:42:33 +10:00
|
|
|
LL| | } else {
|
2024-01-22 12:49:58 +11:00
|
|
|
LL| 0| bail!("error");
|
2023-08-16 12:42:33 +10:00
|
|
|
LL| | }
|
2024-01-22 12:49:58 +11:00
|
|
|
LL| 0| })
|
2023-08-16 12:42:33 +10:00
|
|
|
LL| | };
|
|
|
|
LL| |}
|
|
|
|
LL| |
|
|
|
|
LL| 1|fn load_configuration_files() -> Result<String, String> {
|
|
|
|
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: {}")?;
|
2021-04-30 00:14:51 -07:00
|
|
|
^0
|
2023-08-16 12:42:33 +10:00
|
|
|
LL| |
|
|
|
|
LL| 1| let startup_delay_duration = String::from("arg");
|
|
|
|
LL| 1| let _ = (config, startup_delay_duration);
|
|
|
|
LL| 1| Ok(())
|
|
|
|
LL| 1|}
|
|
|
|
LL| |
|
2023-09-05 23:42:57 +01:00
|
|
|
LL| |#[coverage(off)]
|
2023-08-16 12:42:33 +10:00
|
|
|
LL| |fn main() {
|
2023-08-17 11:24:56 +10:00
|
|
|
LL| | executor::block_on(test()).unwrap();
|
2023-08-16 12:42:33 +10:00
|
|
|
LL| |}
|
|
|
|
LL| |
|
|
|
|
LL| |mod executor {
|
2023-12-15 16:38:27 +11:00
|
|
|
LL| | use core::future::Future;
|
|
|
|
LL| | use core::pin::pin;
|
|
|
|
LL| | use core::task::{Context, Poll, Waker};
|
2023-08-16 12:42:33 +10:00
|
|
|
LL| |
|
2023-09-05 23:42:57 +01:00
|
|
|
LL| | #[coverage(off)]
|
2023-08-16 12:42:33 +10:00
|
|
|
LL| | pub fn block_on<F: Future>(mut future: F) -> F::Output {
|
2023-12-15 16:38:27 +11:00
|
|
|
LL| | let mut future = pin!(future);
|
2024-01-14 16:25:43 -08:00
|
|
|
LL| | let mut context = Context::from_waker(Waker::noop());
|
2023-08-16 12:42:33 +10:00
|
|
|
LL| |
|
|
|
|
LL| | loop {
|
|
|
|
LL| | if let Poll::Ready(val) = future.as_mut().poll(&mut context) {
|
|
|
|
LL| | break val;
|
|
|
|
LL| | }
|
|
|
|
LL| | }
|
|
|
|
LL| | }
|
|
|
|
LL| |}
|
2021-04-30 00:14:51 -07:00
|
|
|
|