mirror of
https://github.com/luanti-org/luanti.git
synced 2025-10-21 11:55:43 +02:00
Fix UB in NetworkPacket class
This commit is contained in:
@@ -63,7 +63,8 @@ void NetworkPacket::putRawPacket(const u8 *data, u32 datasize, session_t peer_id
|
|||||||
|
|
||||||
// split command and datas
|
// split command and datas
|
||||||
m_command = readU16(&data[0]);
|
m_command = readU16(&data[0]);
|
||||||
memcpy(m_data.data(), &data[2], m_datasize);
|
if (m_datasize > 0)
|
||||||
|
memcpy(m_data.data(), &data[2], m_datasize);
|
||||||
}
|
}
|
||||||
|
|
||||||
void NetworkPacket::clear()
|
void NetworkPacket::clear()
|
||||||
@@ -553,7 +554,8 @@ Buffer<u8> NetworkPacket::oldForgePacket()
|
|||||||
{
|
{
|
||||||
Buffer<u8> sb(m_datasize + 2);
|
Buffer<u8> sb(m_datasize + 2);
|
||||||
writeU16(&sb[0], m_command);
|
writeU16(&sb[0], m_command);
|
||||||
memcpy(&sb[2], m_data.data(), m_datasize);
|
if (m_datasize > 0)
|
||||||
|
memcpy(&sb[2], m_data.data(), m_datasize);
|
||||||
|
|
||||||
return sb;
|
return sb;
|
||||||
}
|
}
|
||||||
|
Reference in New Issue
Block a user