From 0e276ae009f6f1acb03746b4b0d8b62ea2a635ec Mon Sep 17 00:00:00 2001 From: SirYwell Date: Fri, 22 Nov 2024 09:28:23 +0100 Subject: [PATCH] Send forget packet to avoid invisible chunk sections --- .../impl/fawe/v1_21_3/PaperweightPlatformAdapter.java | 11 +++++++++-- 1 file changed, 9 insertions(+), 2 deletions(-) diff --git a/worldedit-bukkit/adapters/adapter-1_21_3/src/main/java/com/sk89q/worldedit/bukkit/adapter/impl/fawe/v1_21_3/PaperweightPlatformAdapter.java b/worldedit-bukkit/adapters/adapter-1_21_3/src/main/java/com/sk89q/worldedit/bukkit/adapter/impl/fawe/v1_21_3/PaperweightPlatformAdapter.java index de2cf8acfd..e7fb1b3959 100644 --- a/worldedit-bukkit/adapters/adapter-1_21_3/src/main/java/com/sk89q/worldedit/bukkit/adapter/impl/fawe/v1_21_3/PaperweightPlatformAdapter.java +++ b/worldedit-bukkit/adapters/adapter-1_21_3/src/main/java/com/sk89q/worldedit/bukkit/adapter/impl/fawe/v1_21_3/PaperweightPlatformAdapter.java @@ -24,6 +24,7 @@ import net.minecraft.core.Holder; import net.minecraft.core.IdMap; import net.minecraft.core.Registry; +import net.minecraft.network.protocol.game.ClientboundForgetLevelChunkPacket; import net.minecraft.network.protocol.game.ClientboundLevelChunkWithLightPacket; import net.minecraft.server.MinecraftServer; import net.minecraft.server.level.ChunkHolder; @@ -335,7 +336,6 @@ public static void sendChunk(IntPair pair, ServerLevel nmsWorld, int chunkX, int if (chunkHolder == null) { return; } - ChunkPos coordIntPair = new ChunkPos(chunkX, chunkZ); LevelChunk levelChunk; if (PaperLib.isPaper()) { // getChunkAtIfLoadedImmediately is paper only @@ -353,6 +353,10 @@ public static void sendChunk(IntPair pair, ServerLevel nmsWorld, int chunkX, int } MinecraftServer.getServer().execute(() -> { try { + ChunkPos pos = levelChunk.getPos(); + // NOTE: the ClientboundForgetLevelChunkPacket packet is required on 1.21.3 + // as the client won't update empty -> non-empty sections properly otherwise + ClientboundForgetLevelChunkPacket forget = new ClientboundForgetLevelChunkPacket(pos); ClientboundLevelChunkWithLightPacket packet; if (PaperLib.isPaper()) { packet = new ClientboundLevelChunkWithLightPacket( @@ -371,7 +375,10 @@ public static void sendChunk(IntPair pair, ServerLevel nmsWorld, int chunkX, int null ); } - nearbyPlayers(nmsWorld, coordIntPair).forEach(p -> p.connection.send(packet)); + nearbyPlayers(nmsWorld, pos).forEach(p -> { + p.connection.send(forget); + p.connection.send(packet); + }); } finally { NMSAdapter.endChunkPacketSend(nmsWorld.getWorld().getName(), pair, lockHolder); }