1
0

CompressPacket: reserve CompressedSize, not the uncompressed size

+ Assign the length data to a_CompressedData to overwrite it, mirroring the behaviour of cByteBuffer::ReadAll
This commit is contained in:
Tiger Wang 2020-08-21 18:17:45 +01:00
parent 8620f6a13e
commit 440523b022

View File

@ -1743,7 +1743,7 @@ bool cProtocol_1_8_0::CompressPacket(const AString & a_Packet, AString & a_Compr
LengthHeaderBuffer.ReadAll(LengthData); LengthHeaderBuffer.ReadAll(LengthData);
a_CompressedData.reserve(LengthData.size() + UncompressedSize); a_CompressedData.reserve(LengthData.size() + UncompressedSize);
a_CompressedData.append(LengthData.data(), LengthData.size()); a_CompressedData.assign(LengthData.data(), LengthData.size());
a_CompressedData.append(a_Packet); a_CompressedData.append(a_Packet);
return true; return true;
@ -1794,8 +1794,8 @@ bool cProtocol_1_8_0::CompressPacket(const AString & a_Packet, AString & a_Compr
AString LengthData; AString LengthData;
LengthHeaderBuffer.ReadAll(LengthData); LengthHeaderBuffer.ReadAll(LengthData);
a_CompressedData.reserve(LengthData.size() + DataSize); a_CompressedData.reserve(LengthData.size() + CompressedSize);
a_CompressedData.append(LengthData.data(), LengthData.size()); a_CompressedData.assign(LengthData.data(), LengthData.size());
a_CompressedData.append(CompressedData, CompressedSize); a_CompressedData.append(CompressedData, CompressedSize);
return true; return true;