From 321d0400bb8760ab215a602cc74f36a2a7dd6788 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Gustav=20S=C3=B6rn=C3=A4s?= Date: Tue, 13 Oct 2020 17:12:46 +0200 Subject: respect if we're initializing when parsing user state --- mumd/src/network/tcp.rs | 8 ++++++-- 1 file changed, 6 insertions(+), 2 deletions(-) (limited to 'mumd/src/network') diff --git a/mumd/src/network/tcp.rs b/mumd/src/network/tcp.rs index 72a2840..3fc36a3 100644 --- a/mumd/src/network/tcp.rs +++ b/mumd/src/network/tcp.rs @@ -162,7 +162,11 @@ async fn listen( let mut state = state.lock().unwrap(); let session = msg.get_session(); state.audio_mut().add_client(msg.get_session()); //TODO - state.parse_initial_user_state(msg); //TODO only if actually initiating state + if *state.initialized_receiver().borrow() { + state.server_mut().parse_user_state(msg); + } else { + state.parse_initial_user_state(msg); + } let server = state.server_mut(); let user = server.users().get(&session).unwrap(); info!("User {} connected to {}", @@ -175,7 +179,7 @@ async fn listen( } ControlPacket::ChannelState(msg) => { debug!("Channel state received"); - state.lock().unwrap().server_mut().parse_channel_state(msg); + state.lock().unwrap().server_mut().parse_channel_state(msg); //TODO parse initial if initial } ControlPacket::ChannelRemove(msg) => { state.lock().unwrap().server_mut().parse_channel_remove(msg); -- cgit v1.2.1