Don't try to read the data outside of the try-catch
This commit is contained in:
parent
41c86a6548
commit
9c79f489ed
2 changed files with 5 additions and 57 deletions
|
@ -1,4 +1,4 @@
|
||||||
From a5bd0235ffaaae6207d3ac887c2b8ccc2b60d39d Mon Sep 17 00:00:00 2001
|
From ea03a714afb61798851be72f35684477ce4e5710 Mon Sep 17 00:00:00 2001
|
||||||
From: Shane Freeder <theboyetronic@gmail.com>
|
From: Shane Freeder <theboyetronic@gmail.com>
|
||||||
Date: Mon, 15 Apr 2019 02:24:52 +0100
|
Date: Mon, 15 Apr 2019 02:24:52 +0100
|
||||||
Subject: [PATCH] Handle bad chunks more gracefully
|
Subject: [PATCH] Handle bad chunks more gracefully
|
||||||
|
@ -15,16 +15,17 @@ Should Mojang choose to alter this behavior in the future, this change
|
||||||
will simply defer to whatever that new behavior is.
|
will simply defer to whatever that new behavior is.
|
||||||
|
|
||||||
diff --git a/src/main/java/net/minecraft/server/RegionFileCache.java b/src/main/java/net/minecraft/server/RegionFileCache.java
|
diff --git a/src/main/java/net/minecraft/server/RegionFileCache.java b/src/main/java/net/minecraft/server/RegionFileCache.java
|
||||||
index 17e76815ad..2eb7888027 100644
|
index 17e76815ad..369aaa84c4 100644
|
||||||
--- a/src/main/java/net/minecraft/server/RegionFileCache.java
|
--- a/src/main/java/net/minecraft/server/RegionFileCache.java
|
||||||
+++ b/src/main/java/net/minecraft/server/RegionFileCache.java
|
+++ b/src/main/java/net/minecraft/server/RegionFileCache.java
|
||||||
@@ -171,8 +171,20 @@ public class RegionFileCache {
|
@@ -171,8 +171,20 @@ public class RegionFileCache {
|
||||||
private static NBTTagCompound readOversizedChunk(RegionFile regionfile, int i, int j) throws IOException {
|
private static NBTTagCompound readOversizedChunk(RegionFile regionfile, int i, int j) throws IOException {
|
||||||
synchronized (regionfile) {
|
synchronized (regionfile) {
|
||||||
try (DataInputStream datainputstream = regionfile.getReadStream(i & 31, j & 31)) {
|
try (DataInputStream datainputstream = regionfile.getReadStream(i & 31, j & 31)) {
|
||||||
+ // Paper start - Handle bad chunks more gracefully - also handle similarly with oversized data
|
- NBTTagCompound oversizedData = regionfile.getOversizedData(i, j);
|
||||||
NBTTagCompound oversizedData = regionfile.getOversizedData(i, j);
|
|
||||||
- NBTTagCompound chunk = NBTCompressedStreamTools.readNBT(datainputstream);
|
- NBTTagCompound chunk = NBTCompressedStreamTools.readNBT(datainputstream);
|
||||||
|
+ // Paper start - Handle bad chunks more gracefully - also handle similarly with oversized data
|
||||||
|
+ NBTTagCompound oversizedData = null;
|
||||||
+
|
+
|
||||||
+ try {
|
+ try {
|
||||||
+ oversizedData = regionfile.getOversizedData(i, j);
|
+ oversizedData = regionfile.getOversizedData(i, j);
|
||||||
|
|
|
@ -1,53 +0,0 @@
|
||||||
From 6ed3ea16d5ae3197d4539bc110fcc9610b7e9888 Mon Sep 17 00:00:00 2001
|
|
||||||
From: Zach Brown <zach.brown@destroystokyo.com>
|
|
||||||
Date: Tue, 17 Apr 2018 21:26:31 -0400
|
|
||||||
Subject: [PATCH] Handle bad chunks more gracefully
|
|
||||||
|
|
||||||
Prior to this change the server would crash when attempting to load a
|
|
||||||
chunk from a region with bad data.
|
|
||||||
|
|
||||||
After this change the server will defer back to vanilla behavior. At
|
|
||||||
this time, that means attempting to generate a chunk in its place
|
|
||||||
(and occasionally just not generating anything and leaving small
|
|
||||||
holes in the world).
|
|
||||||
|
|
||||||
Should Mojang choose to alter this behavior in the future, this change
|
|
||||||
will simply defer to whatever that new behavior is.
|
|
||||||
|
|
||||||
diff --git a/src/main/java/net/minecraft/server/ChunkProviderServer.java b/src/main/java/net/minecraft/server/ChunkProviderServer.java
|
|
||||||
index de859ffd1..55dada668 100644
|
|
||||||
--- a/src/main/java/net/minecraft/server/ChunkProviderServer.java
|
|
||||||
+++ b/src/main/java/net/minecraft/server/ChunkProviderServer.java
|
|
||||||
@@ -162,6 +162,13 @@ public class ChunkProviderServer implements IChunkProvider {
|
|
||||||
return null;
|
|
||||||
} else {
|
|
||||||
chunk = ChunkIOExecutor.syncChunkLoad(world, loader, this, i, j);
|
|
||||||
+
|
|
||||||
+ // Paper start - If there was an issue loading the chunk from region, stage1 will fail and stage2 will load it sync
|
|
||||||
+ // all we need to do is fetch an instance
|
|
||||||
+ if (chunk == null) {
|
|
||||||
+ chunk = getChunkIfLoaded(i, j);
|
|
||||||
+ }
|
|
||||||
+ // Paper end
|
|
||||||
}
|
|
||||||
} else if (chunk == null && generate) {
|
|
||||||
chunk = originalGetChunkAt(i, j);
|
|
||||||
diff --git a/src/main/java/org/bukkit/craftbukkit/chunkio/ChunkIOProvider.java b/src/main/java/org/bukkit/craftbukkit/chunkio/ChunkIOProvider.java
|
|
||||||
index ef9529add..cdf3b614c 100644
|
|
||||||
--- a/src/main/java/org/bukkit/craftbukkit/chunkio/ChunkIOProvider.java
|
|
||||||
+++ b/src/main/java/org/bukkit/craftbukkit/chunkio/ChunkIOProvider.java
|
|
||||||
@@ -30,6 +30,11 @@ class ChunkIOProvider implements AsynchronousExecutor.CallBackProvider<QueuedChu
|
|
||||||
return null;
|
|
||||||
} catch (IOException ex) {
|
|
||||||
throw new RuntimeException(ex);
|
|
||||||
+ // Paper - Mirror vanilla by catching everything (else) rather than immediately crashing the server
|
|
||||||
+ // stage2 will receive a null chunk and then load it synchronously, where vanilla MC will properly log and recover
|
|
||||||
+ // stage2 will _not_ however return that instance, only load it
|
|
||||||
+ } catch (Exception ex) {
|
|
||||||
+ return null;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
--
|
|
||||||
2.18.0
|
|
||||||
|
|
Loading…
Reference in a new issue