aboutsummaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
Diffstat (limited to 'src')
-rw-r--r--src/common.rs1
-rw-r--r--src/share.rs3
2 files changed, 4 insertions, 0 deletions
diff --git a/src/common.rs b/src/common.rs
index 4e32edc..b888ed7 100644
--- a/src/common.rs
+++ b/src/common.rs
@@ -81,6 +81,7 @@ macro_rules! impl_share {
}
pub async fn close(self) {
+ self.share.bomb.lock().await.defuse();
self.share.close_tx.send(true).ok();
let mut tasks = self.share.tasks.lock().await;
diff --git a/src/share.rs b/src/share.rs
index ad63290..a2afc4c 100644
--- a/src/share.rs
+++ b/src/share.rs
@@ -1,4 +1,5 @@
use super::*;
+use drop_bomb::DropBomb;
use std::{borrow::Cow, collections::HashMap, io, sync::Arc, time::Duration};
use tokio::{
sync::{mpsc, watch, Mutex, RwLock},
@@ -26,6 +27,7 @@ pub(crate) struct RudpShare<S: UdpSender> {
pub(crate) udp_tx: S,
pub(crate) close_tx: watch::Sender<bool>,
pub(crate) tasks: Mutex<JoinSet<()>>,
+ pub(crate) bomb: Mutex<DropBomb>,
}
pub async fn new<S: UdpSender, R: UdpReceiver>(
@@ -51,6 +53,7 @@ pub async fn new<S: UdpSender, R: UdpReceiver>(
})
.collect(),
tasks: Mutex::new(JoinSet::new()),
+ bomb: Mutex::new(DropBomb::new("rudp connection must be explicitly closed")),
});
let mut tasks = share.tasks.lock().await;