From 4a41dab01eda730e1746eccb348461a218c8b6d6 Mon Sep 17 00:00:00 2001 From: Simeon Zahariev <43317481+Apokalip@users.noreply.github.com> Date: Thu, 15 Sep 2022 20:26:54 +0300 Subject: [PATCH] Connection timeout after successful timeout fix (#171) * Fixing connection timeout after while_timeout was refactored wrong making it timeout even after succesful connection Signed-off-by: Apokalip * format Signed-off-by: Apokalip * Fix comment Signed-off-by: Apokalip Signed-off-by: Apokalip --- ui/src-tauri/src/main.rs | 49 +++++++++++++++++++--------------------- 1 file changed, 23 insertions(+), 26 deletions(-) diff --git a/ui/src-tauri/src/main.rs b/ui/src-tauri/src/main.rs index fc609839..bac905ab 100644 --- a/ui/src-tauri/src/main.rs +++ b/ui/src-tauri/src/main.rs @@ -96,23 +96,23 @@ impl AppState { /// Application State pub static APP_STATE: AppState = AppState::new(); -/// Repeatedly executes `f` until the `timeout` is reached calling `exit` to return from the -/// function. -#[inline] -pub fn while_timeout(timeout: Duration, mut f: F, exit: E) -> T -where - F: FnMut(), - E: FnOnce(Instant, Duration) -> T, -{ - let time_start = Instant::now(); - loop { - f(); - if time_start.elapsed() >= timeout { - return exit(time_start, timeout); +/// While with a timeout +/// Loop over body code block until specified time elapses and exits executing a given code block +/// Needs to be a macro to be able to break early in the main loop body code block +/// i.e. loop over waiting to connect and then break the loop, or timeout with Error message after +/// a specified time. +macro_rules! while_w_timeout{ + ($body:block, $timeout_d:expr, $failure:block) => {{ + let time_start = Instant::now(); + let timeout = Duration::from_millis($timeout_d); + loop { + $body + if time_start.elapsed() >= timeout { + $failure + } } - } + }}; } - /// User pub struct User { /// Main Window @@ -177,23 +177,20 @@ impl Authorizer for User { fn setup<'s>(&'s mut self, setup: &'s Setup) -> UnitFuture<'s> { let window = self.window.clone(); Box::pin(async move { - while_timeout( - Duration::from_millis(5000), - move || { + while_w_timeout!( + { if APP_STATE.get_ui_connected() { - return; + break; } window .emit("connect", setup) .expect("The `connect` command failed to be emitted to the window."); }, - move |time_start, timeout| { - panic!( - "Connection attempt timed-out! Started: {:?} with {:?} timeout.", - time_start, timeout - ); - }, - ) + 5000, + { + panic!("Connection attempt timedout!"); + } + ); }) }