mirror of
https://github.com/PaperMC/Paper.git
synced 2025-01-24 17:22:55 +01:00
d719a30af5
This will discard extra data increasing the size of the chunk from users affected by the bug in the previous commits. The impact of this (affecting all users) is likely to be much higher than users with plugins relying on an API introduced within the last 12 hours. By: md_5 <git@md-5.net>
57 lines
3.2 KiB
Diff
57 lines
3.2 KiB
Diff
--- a/net/minecraft/server/ChunkRegionLoader.java
|
|
+++ b/net/minecraft/server/ChunkRegionLoader.java
|
|
@@ -91,7 +91,7 @@
|
|
|
|
if (nbttagcompound1.hasKeyOfType("TileTicks", 9)) {
|
|
nbttaglist1 = nbttagcompound1.getList("TileTicks", 10);
|
|
- function = IRegistry.BLOCK::getKey;
|
|
+ function = (block) -> IRegistry.BLOCK.getKey((Block) block); // CraftBukkit - decompile error
|
|
registryblocks = IRegistry.BLOCK;
|
|
registryblocks.getClass();
|
|
object1 = TickListChunk.a(nbttaglist1, function, registryblocks::get);
|
|
@@ -103,7 +103,7 @@
|
|
|
|
if (nbttagcompound1.hasKeyOfType("LiquidTicks", 9)) {
|
|
nbttaglist1 = nbttagcompound1.getList("LiquidTicks", 10);
|
|
- function = IRegistry.FLUID::getKey;
|
|
+ function = (fluid) -> IRegistry.FLUID.getKey((FluidType) fluid); // CraftBukkit - decompile error
|
|
registryblocks = IRegistry.FLUID;
|
|
registryblocks.getClass();
|
|
object2 = TickListChunk.a(nbttaglist1, function, registryblocks::get);
|
|
@@ -113,6 +113,12 @@
|
|
|
|
object = new Chunk(worldserver.getMinecraftWorld(), chunkcoordintpair, biomestorage, chunkconverter, (TickList) object1, (TickList) object2, j, achunksection, (chunk) -> {
|
|
loadEntities(nbttagcompound1, chunk);
|
|
+ // CraftBukkit start - load chunk persistent data from nbt
|
|
+ NBTBase persistentBase = nbttagcompound1.get("ChunkBukkitValues");
|
|
+ if (persistentBase instanceof NBTTagCompound) {
|
|
+ chunk.persistentDataContainer.putAll((NBTTagCompound) persistentBase);
|
|
+ }
|
|
+ // CraftBukkit end
|
|
});
|
|
} else {
|
|
ProtoChunk protochunk = new ProtoChunk(chunkcoordintpair, chunkconverter, achunksection, protochunkticklist, protochunkticklist1);
|
|
@@ -246,8 +252,9 @@
|
|
NBTTagCompound nbttagcompound2;
|
|
|
|
for (int i = -1; i < 17; ++i) {
|
|
+ int finalI = i; // CraftBukkit - decompile errors
|
|
ChunkSection chunksection = (ChunkSection) Arrays.stream(achunksection).filter((chunksection1) -> {
|
|
- return chunksection1 != null && chunksection1.getYPosition() >> 4 == i;
|
|
+ return chunksection1 != null && chunksection1.getYPosition() >> 4 == finalI; // CraftBukkit - decompile errors
|
|
}).findFirst().orElse(Chunk.a);
|
|
NibbleArray nibblearray = lightenginethreaded.a(EnumSkyBlock.BLOCK).a(SectionPosition.a(chunkcoordintpair, i));
|
|
NibbleArray nibblearray1 = lightenginethreaded.a(EnumSkyBlock.SKY).a(SectionPosition.a(chunkcoordintpair, i));
|
|
@@ -302,6 +309,12 @@
|
|
if (ichunkaccess.getChunkStatus().getType() == ChunkStatus.Type.LEVELCHUNK) {
|
|
Chunk chunk = (Chunk) ichunkaccess;
|
|
|
|
+ // CraftBukkit start - store chunk persistent data in nbt
|
|
+ if (!chunk.persistentDataContainer.isEmpty()) {
|
|
+ nbttagcompound1.set("ChunkBukkitValues", chunk.persistentDataContainer.toTagCompound());
|
|
+ }
|
|
+ // CraftBukkit end
|
|
+
|
|
chunk.d(false);
|
|
|
|
for (int j = 0; j < chunk.getEntitySlices().length; ++j) {
|