From b2c77985c134315813f0b3f7a116dec7a190618b Mon Sep 17 00:00:00 2001 From: Youwen Wu Date: Thu, 7 Mar 2024 12:31:18 -0800 Subject: [PATCH] fix: refactor telemetry to use new method --- client/src-tauri/src/telemetry/mod.rs | 12 ++++++++++-- 1 file changed, 10 insertions(+), 2 deletions(-) diff --git a/client/src-tauri/src/telemetry/mod.rs b/client/src-tauri/src/telemetry/mod.rs index fd409d9..2db5c7d 100644 --- a/client/src-tauri/src/telemetry/mod.rs +++ b/client/src-tauri/src/telemetry/mod.rs @@ -1,4 +1,4 @@ -use network_tables::v4::MessageData; +use network_tables::v4::{MessageData, Subscription}; use serde_json::to_string; use tauri::{AppHandle, Manager}; mod check_triggers; @@ -27,7 +27,15 @@ pub async fn subscribe_topics( // I hope this doesn't lead to a catastrophic infinite loop failure let client = create_client(&app_handle, &ntable_ip, &ntable_port).await; - let mut subscription = create_subscription(&client).await; + let mut subscription: Subscription = match create_subscription(&client).await { + Ok(subscription) => subscription, + Err(_) => { + app_handle + .emit_all("telemetry_status", "disconnected") + .expect("Failed to emit telemetry_disconnected event"); + continue; + } + }; while let Some(mut message) = subscription.next().await { process_message(&mut message);