aboutsummaryrefslogtreecommitdiff
path: root/Minecraft.World/TexturePacket.cpp
diff options
context:
space:
mode:
authorLoki <lokirautio@gmail.com>2026-03-09 06:53:08 -0500
committerGitHub <noreply@github.com>2026-03-09 06:53:08 -0500
commitbda3b1078ac357b805156a8802a0649f7021716e (patch)
tree838cf12ae598a810fb90a6e455f7fc03131f1342 /Minecraft.World/TexturePacket.cpp
parenta358a3caaee2a4781f910cfb440bd822ae73a7e5 (diff)
Port over RCE Patches from LCEMP (#1023)
* LCEMP RCE Fixes WIP Based on https://github.com/LCEMP/LCEMP/commit/d017bfc30a68888bf5c79b23cf5c4f607cf828bf * Update to LCEMP's ByteArrayIO version Fixes compilation since ours was missing some revisions from LCEMP * Add additional safety checks missed in first pass * Remove duplicate recipe count check
Diffstat (limited to 'Minecraft.World/TexturePacket.cpp')
-rw-r--r--Minecraft.World/TexturePacket.cpp25
1 files changed, 17 insertions, 8 deletions
diff --git a/Minecraft.World/TexturePacket.cpp b/Minecraft.World/TexturePacket.cpp
index eadcb3ed..94c195a0 100644
--- a/Minecraft.World/TexturePacket.cpp
+++ b/Minecraft.World/TexturePacket.cpp
@@ -37,17 +37,26 @@ void TexturePacket::handle(PacketListener *listener)
void TexturePacket::read(DataInputStream *dis) //throws IOException
{
textureName = dis->readUTF();
- dwBytes = static_cast<DWORD>(dis->readShort());
+ short rawBytes = dis->readShort();
+ if (rawBytes <= 0)
+ {
+ dwBytes = 0;
+ return;
+ }
+ dwBytes = (DWORD)(unsigned short)rawBytes;
+ if (dwBytes > 65536)
+ {
+ dwBytes = 0;
+ return;
+ }
+
+ this->pbData= new BYTE [dwBytes];
- if(dwBytes>0)
+ for(DWORD i=0;i<dwBytes;i++)
{
- this->pbData= new BYTE [dwBytes];
-
- for(DWORD i=0;i<dwBytes;i++)
- {
- this->pbData[i] = dis->readByte();
- }
+ this->pbData[i] = dis->readByte();
}
+
}
void TexturePacket::write(DataOutputStream *dos) //throws IOException