aboutsummaryrefslogtreecommitdiffstats
path: root/mumd/src/command.rs
diff options
context:
space:
mode:
authorGustav Sörnäs <gustav@sornas.net>2021-04-19 23:17:52 +0200
committerGitHub <noreply@github.com>2021-04-19 23:17:52 +0200
commit182222664a513ef2b2da74e6b4f67274338b5a77 (patch)
tree16ff6ca08aaeb5f6cbde8289940b56623b8706d0 /mumd/src/command.rs
parent61ad0c5f80c79911cce00263d4b1bd3e2f2defe8 (diff)
parent4da882513c9a692161ff00e4421325ffc7d4af24 (diff)
downloadmum-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.rs10
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();