From d14ee66f4157256dc65e95be0f8e25f90c74dea8 Mon Sep 17 00:00:00 2001 From: Sunil Nimmagadda Date: Mon, 28 Nov 2022 15:01:40 +0530 Subject: Move main.rs to bin. --- src/bin/main.rs | 43 +++++++++++++++++++++++++++++++++++++++++++ src/main.rs | 43 ------------------------------------------- 2 files changed, 43 insertions(+), 43 deletions(-) create mode 100644 src/bin/main.rs delete mode 100644 src/main.rs diff --git a/src/bin/main.rs b/src/bin/main.rs new file mode 100644 index 0000000..7d31e24 --- /dev/null +++ b/src/bin/main.rs @@ -0,0 +1,43 @@ +use tokio::signal::unix::{signal, SignalKind}; +use tokio::time; + +const ADV_INTERVAL: u64 = 3; +const SKEW_INTERVAL: u64 = 1; + +async fn advert_handler() { + println!("3 second timer fired"); +} + +async fn skew_handler() { + println!("1 second timer fired"); +} + +async fn sighup_handler() { + println!("got SIGHUP"); +} + +#[tokio::main(flavor = "current_thread")] +async fn main() { + let advert_handle = tokio::spawn(async move { + let mut advert_interval = time::interval(time::Duration::from_secs(ADV_INTERVAL)); + loop { + advert_interval.tick().await; + advert_handler().await; + } + }); + let skew_handle = tokio::spawn(async move { + let mut skew_interval = time::interval(time::Duration::from_secs(SKEW_INTERVAL)); + loop { + skew_interval.tick().await; + skew_handler().await; + } + }); + let sighup_handle = tokio::spawn(async move { + let mut stream = signal(SignalKind::hangup()).expect("Should be a signal stream"); + loop { + stream.recv().await; + sighup_handler().await; + } + }); + let (_, _, _) = tokio::join!(advert_handle, skew_handle, sighup_handle); +} diff --git a/src/main.rs b/src/main.rs deleted file mode 100644 index 7d31e24..0000000 --- a/src/main.rs +++ /dev/null @@ -1,43 +0,0 @@ -use tokio::signal::unix::{signal, SignalKind}; -use tokio::time; - -const ADV_INTERVAL: u64 = 3; -const SKEW_INTERVAL: u64 = 1; - -async fn advert_handler() { - println!("3 second timer fired"); -} - -async fn skew_handler() { - println!("1 second timer fired"); -} - -async fn sighup_handler() { - println!("got SIGHUP"); -} - -#[tokio::main(flavor = "current_thread")] -async fn main() { - let advert_handle = tokio::spawn(async move { - let mut advert_interval = time::interval(time::Duration::from_secs(ADV_INTERVAL)); - loop { - advert_interval.tick().await; - advert_handler().await; - } - }); - let skew_handle = tokio::spawn(async move { - let mut skew_interval = time::interval(time::Duration::from_secs(SKEW_INTERVAL)); - loop { - skew_interval.tick().await; - skew_handler().await; - } - }); - let sighup_handle = tokio::spawn(async move { - let mut stream = signal(SignalKind::hangup()).expect("Should be a signal stream"); - loop { - stream.recv().await; - sighup_handler().await; - } - }); - let (_, _, _) = tokio::join!(advert_handle, skew_handle, sighup_handle); -} -- cgit v1.2.3