diff options
| author | Gustav Sörnäs <gustav@sornas.net> | 2021-04-19 23:17:52 +0200 |
|---|---|---|
| committer | GitHub <noreply@github.com> | 2021-04-19 23:17:52 +0200 |
| commit | 182222664a513ef2b2da74e6b4f67274338b5a77 (patch) | |
| tree | 16ff6ca08aaeb5f6cbde8289940b56623b8706d0 /mumd/src/command.rs | |
| parent | 61ad0c5f80c79911cce00263d4b1bd3e2f2defe8 (diff) | |
| parent | 4da882513c9a692161ff00e4421325ffc7d4af24 (diff) | |
| download | mum-182222664a513ef2b2da74e6b4f67274338b5a77.tar.gz | |
Merge pull request #90 from mum-rs/server-list-parallel
Diffstat (limited to 'mumd/src/command.rs')
| -rw-r--r-- | mumd/src/command.rs | 10 |
1 files changed, 7 insertions, 3 deletions
diff --git a/mumd/src/command.rs b/mumd/src/command.rs index 7eec388..1337dce 100644 --- a/mumd/src/command.rs +++ b/mumd/src/command.rs @@ -8,7 +8,7 @@ use crate::state::{ExecutionContext, State}; use log::*; use mumble_protocol::{Serverbound, control::ControlPacket}; use mumlib::command::{Command, CommandResponse}; -use std::sync::{Arc, RwLock}; +use std::sync::{atomic::{AtomicU64, Ordering}, Arc, RwLock}; use tokio::sync::{mpsc, oneshot, watch}; pub async fn handle( @@ -23,6 +23,7 @@ pub async fn handle( mut connection_info_sender: watch::Sender<Option<ConnectionInfo>>, ) { debug!("Begin listening for commands"); + let ping_count = AtomicU64::new(0); while let Some((command, response_sender)) = command_receiver.recv().await { debug!("Received command {:?}", command); let mut state = state.write().unwrap(); @@ -47,10 +48,13 @@ pub async fn handle( response_sender.send(generator()).unwrap(); } ExecutionContext::Ping(generator, converter) => { - match generator() { + let ret = generator(); + debug!("Ping generated: {:?}", ret); + match ret { Ok(addr) => { + let id = ping_count.fetch_add(1, Ordering::Relaxed); let res = ping_request_sender.send(( - 0, + id, addr, Box::new(move |packet| { response_sender.send(converter(packet)).unwrap(); |
