From 4f1df53f075831fcd6154a54964d98559ef38964 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?J=C3=A9r=C3=B4me=20Leclercq?= Date: Tue, 31 Jan 2017 15:31:11 +0100 Subject: [PATCH] Network/ENetPeer: Fix DisconnectLater not waiting for pending commands --- src/Nazara/Network/ENetPeer.cpp | 4 +++- 1 file changed, 3 insertions(+), 1 deletion(-) diff --git a/src/Nazara/Network/ENetPeer.cpp b/src/Nazara/Network/ENetPeer.cpp index e90d77954..ae0952be5 100644 --- a/src/Nazara/Network/ENetPeer.cpp +++ b/src/Nazara/Network/ENetPeer.cpp @@ -83,7 +83,7 @@ namespace Nz void ENetPeer::DisconnectLater(UInt32 data) { - if (IsConnected() && !m_outgoingReliableCommands.empty() && !m_outgoingUnreliableCommands.empty() && !m_sentReliableCommands.empty()) + if (IsConnected() && HasPendingCommands()) { m_state = ENetPeerState::DisconnectLater; m_eventData = data; @@ -596,10 +596,12 @@ namespace Nz Reset(); } else + { if (command->header.command & ENetProtocolFlag_Acknowledge) ChangeState(ENetPeerState::AcknowledgingDisconnect); else DispatchState(ENetPeerState::Zombie); + } } if (m_state != ENetPeerState::Disconnected)