2021-12-19 18:15:22 +01:00
From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001
From: Spottedleaf <Spottedleaf@users.noreply.github.com>
Date: Sun, 19 Dec 2021 09:13:41 -0800
Subject: [PATCH] Only write chunk data to disk if it serializes without
throwing
This ensures at least a valid version of the chunk exists
on disk, even if outdated
2022-02-05 20:47:11 +01:00
diff --git a/src/main/java/net/minecraft/world/level/chunk/storage/RegionFile.java b/src/main/java/net/minecraft/world/level/chunk/storage/RegionFile.java
2024-01-23 14:34:17 +01:00
index cd362c5ee40e6542a42ee7429072e312569e5999..bbb134d82b30905b3213df9b855e7cf94ad71279 100644
2022-02-05 20:47:11 +01:00
--- a/src/main/java/net/minecraft/world/level/chunk/storage/RegionFile.java
+++ b/src/main/java/net/minecraft/world/level/chunk/storage/RegionFile.java
2024-01-22 21:04:08 +01:00
@@ -529,6 +529,9 @@ public class RegionFile implements AutoCloseable {
2022-08-10 17:07:49 +02:00
}
}
+
+ public static final int MAX_CHUNK_SIZE = 500 * 1024 * 1024; // Paper - don't write garbage data to disk if writing serialization fails
+
// Paper end
private class ChunkBuffer extends ByteArrayOutputStream {
2024-01-22 21:04:08 +01:00
@@ -544,6 +547,24 @@ public class RegionFile implements AutoCloseable {
2022-02-05 20:47:11 +01:00
this.pos = chunkcoordintpair;
}
+ // Paper start - don't write garbage data to disk if writing serialization fails
+ @Override
+ public void write(final int b) {
2022-08-10 17:07:49 +02:00
+ if (this.count > MAX_CHUNK_SIZE) {
2022-02-05 20:47:11 +01:00
+ throw new RegionFileStorage.RegionFileSizeException("Region file too large: " + this.count);
+ }
+ super.write(b);
+ }
+
+ @Override
+ public void write(final byte[] b, final int off, final int len) {
2022-08-10 17:07:49 +02:00
+ if (this.count + len > MAX_CHUNK_SIZE) {
2022-02-05 20:47:11 +01:00
+ throw new RegionFileStorage.RegionFileSizeException("Region file too large: " + (this.count + len));
+ }
+ super.write(b, off, len);
+ }
2024-01-18 22:00:40 +01:00
+ // Paper end - don't write garbage data to disk if writing serialization fails
2022-02-05 20:47:11 +01:00
+
public void close() throws IOException {
ByteBuffer bytebuffer = ByteBuffer.wrap(this.buf, 0, this.count);
2021-12-19 18:15:22 +01:00
diff --git a/src/main/java/net/minecraft/world/level/chunk/storage/RegionFileStorage.java b/src/main/java/net/minecraft/world/level/chunk/storage/RegionFileStorage.java
2024-01-23 14:34:17 +01:00
index 88e4efd686d64aa5049d92416fb27589d0e58753..753a9ddfabaab0014f68426c8e44213912faf021 100644
2021-12-19 18:15:22 +01:00
--- a/src/main/java/net/minecraft/world/level/chunk/storage/RegionFileStorage.java
+++ b/src/main/java/net/minecraft/world/level/chunk/storage/RegionFileStorage.java
2024-01-22 21:04:08 +01:00
@@ -286,10 +286,17 @@ public class RegionFileStorage implements AutoCloseable {
2021-12-19 18:15:22 +01:00
NbtIo.write(nbt, (DataOutput) dataoutputstream);
2024-01-21 12:53:04 +01:00
regionfile.setStatus(pos.x, pos.z, ChunkSerializer.getStatus(nbt)); // Paper - Cache chunk status
2021-12-19 18:15:22 +01:00
regionfile.setOversized(pos.x, pos.z, false); // Paper - We don't do this anymore, mojang stores differently, but clear old meta flag if it exists to get rid of our own meta file once last oversized is gone
+ dataoutputstream.close(); // Paper - only write if successful
2024-01-21 12:53:04 +01:00
+ // Paper start - don't write garbage data to disk if writing serialization fails
2022-02-05 20:47:11 +01:00
+ } catch (RegionFileSizeException e) {
+ attempts = 5; // Don't retry
+ regionfile.clear(pos);
+ throw e;
+ // Paper end - don't write garbage data to disk if writing serialization fails
2021-12-19 18:15:22 +01:00
} catch (Throwable throwable) {
if (dataoutputstream != null) {
try {
- dataoutputstream.close();
+ //dataoutputstream.close(); // Paper - don't write garbage data to disk if writing serialization fails
} catch (Throwable throwable1) {
throwable.addSuppressed(throwable1);
}
2024-01-22 21:04:08 +01:00
@@ -297,10 +304,7 @@ public class RegionFileStorage implements AutoCloseable {
2021-12-19 18:15:22 +01:00
throw throwable;
}
-
- if (dataoutputstream != null) {
- dataoutputstream.close();
- }
2024-01-18 22:00:40 +01:00
+ // Paper - don't write garbage data to disk if writing serialization fails; move into try block to only write if successfully serialized
2021-12-19 18:15:22 +01:00
}
2024-01-23 14:34:17 +01:00
// Paper start - Chunk save reattempt
2023-06-08 11:18:51 +02:00
return;
2024-01-22 21:04:08 +01:00
@@ -346,4 +350,13 @@ public class RegionFileStorage implements AutoCloseable {
2022-02-05 20:47:11 +01:00
}
}
+
2024-01-18 22:00:40 +01:00
+ // Paper start - don't write garbage data to disk if writing serialization fails
2022-02-05 20:47:11 +01:00
+ public static final class RegionFileSizeException extends RuntimeException {
+
+ public RegionFileSizeException(String message) {
+ super(message);
+ }
+ }
2024-01-18 22:00:40 +01:00
+ // Paper end - don't write garbage data to disk if writing serialization fails
2022-02-05 20:47:11 +01:00
}