From 576d765557621b504ca6ec008c6d59f00bcc6c6d Mon Sep 17 00:00:00 2001 From: Lion Kortlepel Date: Fri, 1 Nov 2024 15:07:54 +0100 Subject: [PATCH] fix crash when double closing --- src/Client.cpp | 18 +++++++++++------- 1 file changed, 11 insertions(+), 7 deletions(-) diff --git a/src/Client.cpp b/src/Client.cpp index ae30334f..6311e2e4 100644 --- a/src/Client.cpp +++ b/src/Client.cpp @@ -79,13 +79,17 @@ std::string TClient::GetCarPositionRaw(int Ident) { void TClient::Disconnect(std::string_view Reason) { beammp_debugf("Disconnecting client {} for reason: {}", GetID(), Reason); boost::system::error_code ec; - mSocket.shutdown(socket_base::shutdown_both, ec); - if (ec) { - beammp_debugf("Failed to shutdown client socket: {}", ec.message()); - } - mSocket.close(ec); - if (ec) { - beammp_debugf("Failed to close client socket: {}", ec.message()); + if (mSocket.is_open()) { + mSocket.shutdown(socket_base::shutdown_both, ec); + if (ec) { + beammp_debugf("Failed to shutdown client socket: {}", ec.message()); + } + mSocket.close(ec); + if (ec) { + beammp_debugf("Failed to close client socket: {}", ec.message()); + } + } else { + beammp_debug("Socket is already closed."); } }