diff options
| author | oldmud0 <oldmud0@users.noreply.github.com> | 2018-07-05 21:06:02 -0500 |
|---|---|---|
| committer | oldmud0 <oldmud0@users.noreply.github.com> | 2018-07-05 21:06:02 -0500 |
| commit | a7c63a44c67f175495b5fa3b6cca9a5015fbe108 (patch) | |
| tree | 90aafee1e132b232893021bd67adfb94eb96af96 | |
| parent | 7e4be0edd7756220dd8d7fbaaaf3d972db48df5e (diff) | |
| parent | e761805cd188337a5d5997dcf3389be9ee4316bd (diff) | |
Merge remote-tracking branch 'upstream/master'
| -rw-r--r-- | networkmanager.cpp | 13 | ||||
| -rw-r--r-- | networkmanager.h | 3 |
2 files changed, 11 insertions, 5 deletions
diff --git a/networkmanager.cpp b/networkmanager.cpp index e58c85e3..e7246fe3 100644 --- a/networkmanager.cpp +++ b/networkmanager.cpp @@ -4,6 +4,7 @@ #include "debug_functions.h" #include "lobby.h" +#include <cstring> NetworkManager::NetworkManager(AOApplication *parent) : QObject(parent) { @@ -80,8 +81,9 @@ void NetworkManager::ship_server_packet(QString p_packet) void NetworkManager::handle_ms_packet() { - char buffer[16384] = {0}; - ms_socket->read(buffer, ms_socket->bytesAvailable()); + char buffer[buffer_max_size]; + std::memset(buffer, 0, buffer_max_size); + ms_socket->read(buffer, buffer_max_size); QString in_data = buffer; @@ -105,7 +107,7 @@ void NetworkManager::handle_ms_packet() QStringList packet_list = in_data.split("%", QString::SplitBehavior(QString::SkipEmptyParts)); for (QString packet : packet_list) - { + { AOPacket *f_packet = new AOPacket(packet); ao_app->ms_packet_received(f_packet); @@ -218,8 +220,9 @@ void NetworkManager::retry_ms_connect() void NetworkManager::handle_server_packet() { - char buffer[16384] = {0}; - server_socket->read(buffer, server_socket->bytesAvailable()); + char buffer[buffer_max_size]; + std::memset(buffer, 0, buffer_max_size); + server_socket->read(buffer, buffer_max_size); QString in_data = buffer; diff --git a/networkmanager.h b/networkmanager.h index 6954d19e..99987f3b 100644 --- a/networkmanager.h +++ b/networkmanager.h @@ -48,6 +48,9 @@ public: const int ms_reconnect_delay_ms = 7000; + // kind of arbitrary max buffer size + const size_t buffer_max_size = 16384; + bool ms_partial_packet = false; QString ms_temp_packet = ""; |
