aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authoroldmud0 <oldmud0@users.noreply.github.com>2018-07-05 21:06:02 -0500
committeroldmud0 <oldmud0@users.noreply.github.com>2018-07-05 21:06:02 -0500
commita7c63a44c67f175495b5fa3b6cca9a5015fbe108 (patch)
tree90aafee1e132b232893021bd67adfb94eb96af96
parent7e4be0edd7756220dd8d7fbaaaf3d972db48df5e (diff)
parente761805cd188337a5d5997dcf3389be9ee4316bd (diff)
Merge remote-tracking branch 'upstream/master'
-rw-r--r--networkmanager.cpp13
-rw-r--r--networkmanager.h3
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 = "";