spigot/CraftBukkit-Patches/0041-Catch-stalling-on-corrupted-map-data-NBT-arrays.patch

34 lines
1.6 KiB
Diff
Raw Normal View History

2021-04-07 15:03:34 +10:00
From 15f74be02b53128fdb5cd884b69d732f74429d19 Mon Sep 17 00:00:00 2001
2019-12-11 09:00:00 +11:00
From: md_5 <git@md-5.net>
Date: Mon, 20 Jan 2014 13:44:07 +1100
Subject: [PATCH] Catch stalling on corrupted map data / NBT arrays.
2021-03-16 09:00:00 +11:00
diff --git a/src/main/java/net/minecraft/nbt/NBTTagByteArray.java b/src/main/java/net/minecraft/nbt/NBTTagByteArray.java
2021-04-07 15:03:34 +10:00
index 85988fac0..c2a597bd4 100644
2021-03-16 09:00:00 +11:00
--- a/src/main/java/net/minecraft/nbt/NBTTagByteArray.java
+++ b/src/main/java/net/minecraft/nbt/NBTTagByteArray.java
2021-04-07 15:03:34 +10:00
@@ -18,6 +18,7 @@ public class NBTTagByteArray extends NBTList<NBTTagByte> {
2019-12-11 09:00:00 +11:00
public NBTTagByteArray b(DataInput datainput, int i, NBTReadLimiter nbtreadlimiter) throws IOException {
nbtreadlimiter.a(192L);
int j = datainput.readInt();
+ com.google.common.base.Preconditions.checkArgument( j < 1 << 24); // Spigot
nbtreadlimiter.a(8L * (long) j);
byte[] abyte = new byte[j];
2021-03-16 09:00:00 +11:00
diff --git a/src/main/java/net/minecraft/nbt/NBTTagIntArray.java b/src/main/java/net/minecraft/nbt/NBTTagIntArray.java
2021-04-07 15:03:34 +10:00
index 22f5c22c4..c7589dc3d 100644
2021-03-16 09:00:00 +11:00
--- a/src/main/java/net/minecraft/nbt/NBTTagIntArray.java
+++ b/src/main/java/net/minecraft/nbt/NBTTagIntArray.java
2021-04-07 15:03:34 +10:00
@@ -18,6 +18,7 @@ public class NBTTagIntArray extends NBTList<NBTTagInt> {
2019-12-11 09:00:00 +11:00
public NBTTagIntArray b(DataInput datainput, int i, NBTReadLimiter nbtreadlimiter) throws IOException {
nbtreadlimiter.a(192L);
int j = datainput.readInt();
+ com.google.common.base.Preconditions.checkArgument( j < 1 << 24); // Spigot
nbtreadlimiter.a(32L * (long) j);
int[] aint = new int[j];
--
2.25.1
2019-12-11 09:00:00 +11:00