mirror of
https://github.com/PaperMC/Paper.git
synced 2025-01-03 06:47:34 +01:00
Fix oversized chunk merging
This commit is contained in:
parent
8e5d5b8753
commit
0440a08b8d
@ -142,7 +142,7 @@ index 04e45b4de2f4e26853a4fed6271cf79ef8607154..44de464b5f2190944c7a7316a76e13f9
|
|||||||
|
|
||||||
private final ChunkPos pos;
|
private final ChunkPos pos;
|
||||||
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
|
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
|
||||||
index 40830a2b231df9bbf676d8325e76c8252a6c1d6c..164db987210aae06432a6abd9b22796c2168e212 100644
|
index 40830a2b231df9bbf676d8325e76c8252a6c1d6c..2cbc17288b1dc52edb2bdad29976d0f551b1e176 100644
|
||||||
--- a/src/main/java/net/minecraft/world/level/chunk/storage/RegionFileStorage.java
|
--- a/src/main/java/net/minecraft/world/level/chunk/storage/RegionFileStorage.java
|
||||||
+++ b/src/main/java/net/minecraft/world/level/chunk/storage/RegionFileStorage.java
|
+++ b/src/main/java/net/minecraft/world/level/chunk/storage/RegionFileStorage.java
|
||||||
@@ -11,8 +11,10 @@ import java.nio.file.Files;
|
@@ -11,8 +11,10 @@ import java.nio.file.Files;
|
||||||
@ -156,7 +156,7 @@ index 40830a2b231df9bbf676d8325e76c8252a6c1d6c..164db987210aae06432a6abd9b22796c
|
|||||||
import net.minecraft.util.ExceptionCollector;
|
import net.minecraft.util.ExceptionCollector;
|
||||||
import net.minecraft.world.level.ChunkPos;
|
import net.minecraft.world.level.ChunkPos;
|
||||||
|
|
||||||
@@ -79,6 +81,74 @@ public class RegionFileStorage implements AutoCloseable {
|
@@ -79,6 +81,71 @@ public class RegionFileStorage implements AutoCloseable {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -190,12 +190,9 @@ index 40830a2b231df9bbf676d8325e76c8252a6c1d6c..164db987210aae06432a6abd9b22796c
|
|||||||
+ return chunk;
|
+ return chunk;
|
||||||
+ }
|
+ }
|
||||||
+ CompoundTag oversizedLevel = oversizedData.getCompound("Level");
|
+ CompoundTag oversizedLevel = oversizedData.getCompound("Level");
|
||||||
+ CompoundTag level = chunk.getCompound("Level");
|
|
||||||
+
|
+
|
||||||
+ mergeChunkList(level, oversizedLevel, "Entities");
|
+ mergeChunkList(chunk, oversizedLevel, "entities", "Entities");
|
||||||
+ mergeChunkList(level, oversizedLevel, "TileEntities");
|
+ mergeChunkList(chunk, oversizedLevel, "block_entities", "TileEntities");
|
||||||
+
|
|
||||||
+ chunk.put("Level", level);
|
|
||||||
+
|
+
|
||||||
+ return chunk;
|
+ return chunk;
|
||||||
+ } catch (Throwable throwable) {
|
+ } catch (Throwable throwable) {
|
||||||
@ -205,9 +202,9 @@ index 40830a2b231df9bbf676d8325e76c8252a6c1d6c..164db987210aae06432a6abd9b22796c
|
|||||||
+ }
|
+ }
|
||||||
+ }
|
+ }
|
||||||
+
|
+
|
||||||
+ private static void mergeChunkList(CompoundTag level, CompoundTag oversizedLevel, String key) {
|
+ private static void mergeChunkList(CompoundTag level, CompoundTag oversizedLevel, String key, String oversizedKey) {
|
||||||
+ ListTag levelList = level.getList(key, 10);
|
+ ListTag levelList = level.getList(key, 10);
|
||||||
+ ListTag oversizedList = oversizedLevel.getList(key, 10);
|
+ ListTag oversizedList = oversizedLevel.getList(oversizedKey, 10);
|
||||||
+
|
+
|
||||||
+ if (!oversizedList.isEmpty()) {
|
+ if (!oversizedList.isEmpty()) {
|
||||||
+ levelList.addAll(oversizedList);
|
+ levelList.addAll(oversizedList);
|
||||||
@ -231,7 +228,7 @@ index 40830a2b231df9bbf676d8325e76c8252a6c1d6c..164db987210aae06432a6abd9b22796c
|
|||||||
@Nullable
|
@Nullable
|
||||||
public CompoundTag read(ChunkPos pos) throws IOException {
|
public CompoundTag read(ChunkPos pos) throws IOException {
|
||||||
// CraftBukkit start - SPIGOT-5680: There's no good reason to preemptively create files on read, save that for writing
|
// CraftBukkit start - SPIGOT-5680: There's no good reason to preemptively create files on read, save that for writing
|
||||||
@@ -90,6 +160,12 @@ public class RegionFileStorage implements AutoCloseable {
|
@@ -90,6 +157,12 @@ public class RegionFileStorage implements AutoCloseable {
|
||||||
try { // Paper
|
try { // Paper
|
||||||
DataInputStream datainputstream = regionfile.getChunkDataInputStream(pos);
|
DataInputStream datainputstream = regionfile.getChunkDataInputStream(pos);
|
||||||
|
|
||||||
@ -244,7 +241,7 @@ index 40830a2b231df9bbf676d8325e76c8252a6c1d6c..164db987210aae06432a6abd9b22796c
|
|||||||
CompoundTag nbttagcompound;
|
CompoundTag nbttagcompound;
|
||||||
label43:
|
label43:
|
||||||
{
|
{
|
||||||
@@ -172,6 +248,7 @@ public class RegionFileStorage implements AutoCloseable {
|
@@ -172,6 +245,7 @@ public class RegionFileStorage implements AutoCloseable {
|
||||||
|
|
||||||
try {
|
try {
|
||||||
NbtIo.write(nbt, (DataOutput) dataoutputstream);
|
NbtIo.write(nbt, (DataOutput) dataoutputstream);
|
||||||
|
@ -184,10 +184,10 @@ index 44de464b5f2190944c7a7316a76e13f9c3b954ab..293cce2c80fbdc18480977f5f6b24d6b
|
|||||||
this.padToFullSector();
|
this.padToFullSector();
|
||||||
} finally {
|
} finally {
|
||||||
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
|
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
|
||||||
index 164db987210aae06432a6abd9b22796c2168e212..91cf5878dc13e1abca0c301d1346248bda251cbf 100644
|
index 2cbc17288b1dc52edb2bdad29976d0f551b1e176..2ee32657a49937418b352a138aca21fbb27857e6 100644
|
||||||
--- a/src/main/java/net/minecraft/world/level/chunk/storage/RegionFileStorage.java
|
--- a/src/main/java/net/minecraft/world/level/chunk/storage/RegionFileStorage.java
|
||||||
+++ b/src/main/java/net/minecraft/world/level/chunk/storage/RegionFileStorage.java
|
+++ b/src/main/java/net/minecraft/world/level/chunk/storage/RegionFileStorage.java
|
||||||
@@ -248,6 +248,7 @@ public class RegionFileStorage implements AutoCloseable {
|
@@ -245,6 +245,7 @@ public class RegionFileStorage implements AutoCloseable {
|
||||||
|
|
||||||
try {
|
try {
|
||||||
NbtIo.write(nbt, (DataOutput) dataoutputstream);
|
NbtIo.write(nbt, (DataOutput) dataoutputstream);
|
||||||
|
@ -678,7 +678,7 @@ index 293cce2c80fbdc18480977f5f6b24d6b4fa8dcf3..834fa7048e3affb4fcc734d56526b9fb
|
|||||||
return bytebuffer;
|
return bytebuffer;
|
||||||
}
|
}
|
||||||
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
|
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
|
||||||
index 0c5f5b2960f1a0d4bbd41c3c3baf101b4c388c43..cf555bd67599441ce53ae8559c1ffd4bb681ac71 100644
|
index 7b4f3c30cfc4bf68cc872598726f7f7eab5f9830..2dde10324e515bd58fc6ba7e93156ae783492cc2 100644
|
||||||
--- a/src/main/java/net/minecraft/world/level/chunk/storage/RegionFileStorage.java
|
--- a/src/main/java/net/minecraft/world/level/chunk/storage/RegionFileStorage.java
|
||||||
+++ b/src/main/java/net/minecraft/world/level/chunk/storage/RegionFileStorage.java
|
+++ b/src/main/java/net/minecraft/world/level/chunk/storage/RegionFileStorage.java
|
||||||
@@ -26,7 +26,15 @@ public class RegionFileStorage implements AutoCloseable {
|
@@ -26,7 +26,15 @@ public class RegionFileStorage implements AutoCloseable {
|
||||||
@ -709,7 +709,7 @@ index 0c5f5b2960f1a0d4bbd41c3c3baf101b4c388c43..cf555bd67599441ce53ae8559c1ffd4b
|
|||||||
|
|
||||||
this.regionCache.putAndMoveToFirst(i, regionfile1);
|
this.regionCache.putAndMoveToFirst(i, regionfile1);
|
||||||
// Paper start
|
// Paper start
|
||||||
@@ -178,6 +186,13 @@ public class RegionFileStorage implements AutoCloseable {
|
@@ -175,6 +183,13 @@ public class RegionFileStorage implements AutoCloseable {
|
||||||
if (regionfile == null) {
|
if (regionfile == null) {
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
@ -723,7 +723,7 @@ index 0c5f5b2960f1a0d4bbd41c3c3baf101b4c388c43..cf555bd67599441ce53ae8559c1ffd4b
|
|||||||
// CraftBukkit end
|
// CraftBukkit end
|
||||||
try { // Paper
|
try { // Paper
|
||||||
DataInputStream datainputstream = regionfile.getChunkDataInputStream(pos);
|
DataInputStream datainputstream = regionfile.getChunkDataInputStream(pos);
|
||||||
@@ -194,6 +209,20 @@ public class RegionFileStorage implements AutoCloseable {
|
@@ -191,6 +206,20 @@ public class RegionFileStorage implements AutoCloseable {
|
||||||
try {
|
try {
|
||||||
if (datainputstream != null) {
|
if (datainputstream != null) {
|
||||||
nbttagcompound = NbtIo.read((DataInput) datainputstream);
|
nbttagcompound = NbtIo.read((DataInput) datainputstream);
|
||||||
|
@ -4090,10 +4090,10 @@ index 0000000000000000000000000000000000000000..177d0a969f3d72a34e773e8309c3719a
|
|||||||
+}
|
+}
|
||||||
diff --git a/src/main/java/ca/spottedleaf/starlight/common/util/SaveUtil.java b/src/main/java/ca/spottedleaf/starlight/common/util/SaveUtil.java
|
diff --git a/src/main/java/ca/spottedleaf/starlight/common/util/SaveUtil.java b/src/main/java/ca/spottedleaf/starlight/common/util/SaveUtil.java
|
||||||
new file mode 100644
|
new file mode 100644
|
||||||
index 0000000000000000000000000000000000000000..0cfb9c213e7970e98895cafdc9dd4b66cf557d72
|
index 0000000000000000000000000000000000000000..8cb5c999aa48892d0054e769962aca2fb9400e44
|
||||||
--- /dev/null
|
--- /dev/null
|
||||||
+++ b/src/main/java/ca/spottedleaf/starlight/common/util/SaveUtil.java
|
+++ b/src/main/java/ca/spottedleaf/starlight/common/util/SaveUtil.java
|
||||||
@@ -0,0 +1,185 @@
|
@@ -0,0 +1,183 @@
|
||||||
+package ca.spottedleaf.starlight.common.util;
|
+package ca.spottedleaf.starlight.common.util;
|
||||||
+
|
+
|
||||||
+import ca.spottedleaf.starlight.common.light.SWMRNibbleArray;
|
+import ca.spottedleaf.starlight.common.light.SWMRNibbleArray;
|
||||||
@ -4128,8 +4128,8 @@ index 0000000000000000000000000000000000000000..0cfb9c213e7970e98895cafdc9dd4b66
|
|||||||
+ }
|
+ }
|
||||||
+ }
|
+ }
|
||||||
+
|
+
|
||||||
+ private static void saveLightHookReal(final Level world, final ChunkAccess chunk, final CompoundTag nbt) {
|
+ private static void saveLightHookReal(final Level world, final ChunkAccess chunk, final CompoundTag tag) {
|
||||||
+ if (nbt == null) {
|
+ if (tag == null) {
|
||||||
+ return;
|
+ return;
|
||||||
+ }
|
+ }
|
||||||
+
|
+
|
||||||
@ -4139,18 +4139,17 @@ index 0000000000000000000000000000000000000000..0cfb9c213e7970e98895cafdc9dd4b66
|
|||||||
+ SWMRNibbleArray[] blockNibbles = chunk.getBlockNibbles();
|
+ SWMRNibbleArray[] blockNibbles = chunk.getBlockNibbles();
|
||||||
+ SWMRNibbleArray[] skyNibbles = chunk.getSkyNibbles();
|
+ SWMRNibbleArray[] skyNibbles = chunk.getSkyNibbles();
|
||||||
+
|
+
|
||||||
+ CompoundTag level = nbt.getCompound("Level");
|
|
||||||
+ boolean lit = chunk.isLightCorrect() || !(world instanceof ServerLevel);
|
+ boolean lit = chunk.isLightCorrect() || !(world instanceof ServerLevel);
|
||||||
+ // diff start - store our tag for whether light data is init'd
|
+ // diff start - store our tag for whether light data is init'd
|
||||||
+ if (lit) {
|
+ if (lit) {
|
||||||
+ level.putBoolean("isLightOn", false);
|
+ tag.putBoolean("isLightOn", false);
|
||||||
+ }
|
+ }
|
||||||
+ // diff end - store our tag for whether light data is init'd
|
+ // diff end - store our tag for whether light data is init'd
|
||||||
+ ChunkStatus status = ChunkStatus.byName(level.getString("Status"));
|
+ ChunkStatus status = ChunkStatus.byName(tag.getString("Status"));
|
||||||
+
|
+
|
||||||
+ CompoundTag[] sections = new CompoundTag[maxSection - minSection + 1];
|
+ CompoundTag[] sections = new CompoundTag[maxSection - minSection + 1];
|
||||||
+
|
+
|
||||||
+ ListTag sectionsStored = level.getList("Sections", 10);
|
+ ListTag sectionsStored = tag.getList("sections", 10);
|
||||||
+
|
+
|
||||||
+ for (int i = 0; i < sectionsStored.size(); ++i) {
|
+ for (int i = 0; i < sectionsStored.size(); ++i) {
|
||||||
+ CompoundTag sectionStored = sectionsStored.getCompound(i);
|
+ CompoundTag sectionStored = sectionsStored.getCompound(i);
|
||||||
@ -4207,9 +4206,9 @@ index 0000000000000000000000000000000000000000..0cfb9c213e7970e98895cafdc9dd4b66
|
|||||||
+ sectionsStored.add(section);
|
+ sectionsStored.add(section);
|
||||||
+ }
|
+ }
|
||||||
+ }
|
+ }
|
||||||
+ level.put("Sections", sectionsStored);
|
+ tag.put("sections", sectionsStored);
|
||||||
+ if (lit) {
|
+ if (lit) {
|
||||||
+ level.putInt(STARLIGHT_VERSION_TAG, STARLIGHT_LIGHT_VERSION); // only mark as fully lit after we have successfully injected our data
|
+ tag.putInt(STARLIGHT_VERSION_TAG, STARLIGHT_LIGHT_VERSION); // only mark as fully lit after we have successfully injected our data
|
||||||
+ }
|
+ }
|
||||||
+ }
|
+ }
|
||||||
+
|
+
|
||||||
@ -4237,12 +4236,11 @@ index 0000000000000000000000000000000000000000..0cfb9c213e7970e98895cafdc9dd4b66
|
|||||||
+
|
+
|
||||||
+
|
+
|
||||||
+ // start copy from from the original method
|
+ // start copy from from the original method
|
||||||
+ CompoundTag levelTag = tag.getCompound("Level");
|
+ boolean lit = tag.get("isLightOn") != null && tag.getInt(STARLIGHT_VERSION_TAG) == STARLIGHT_LIGHT_VERSION;
|
||||||
+ boolean lit = levelTag.get("isLightOn") != null && levelTag.getInt(STARLIGHT_VERSION_TAG) == STARLIGHT_LIGHT_VERSION;
|
|
||||||
+ boolean canReadSky = world.dimensionType().hasSkyLight();
|
+ boolean canReadSky = world.dimensionType().hasSkyLight();
|
||||||
+ ChunkStatus status = ChunkStatus.byName(tag.getCompound("Level").getString("Status"));
|
+ ChunkStatus status = ChunkStatus.byName(tag.getString("Status"));
|
||||||
+ if (lit && status.isOrAfter(ChunkStatus.LIGHT)) { // diff - we add the status check here
|
+ if (lit && status.isOrAfter(ChunkStatus.LIGHT)) { // diff - we add the status check here
|
||||||
+ ListTag sections = levelTag.getList("Sections", 10);
|
+ ListTag sections = tag.getList("sections", 10);
|
||||||
+
|
+
|
||||||
+ for (int i = 0; i < sections.size(); ++i) {
|
+ for (int i = 0; i < sections.size(); ++i) {
|
||||||
+ CompoundTag sectionData = sections.getCompound(i);
|
+ CompoundTag sectionData = sections.getCompound(i);
|
||||||
|
Loading…
Reference in New Issue
Block a user