From 3f8c2b8e94b990a3e9bc4d7b88aae58e134827d5 Mon Sep 17 00:00:00 2001 From: Maksim Straus <74616162+cqb13@users.noreply.github.com> Date: Mon, 1 Jul 2024 02:58:05 -0400 Subject: [PATCH] fix new-chunks crash with sodium (#366) --- src/main/java/anticope/rejects/modules/NewChunks.java | 5 ++++- 1 file changed, 4 insertions(+), 1 deletion(-) diff --git a/src/main/java/anticope/rejects/modules/NewChunks.java b/src/main/java/anticope/rejects/modules/NewChunks.java index 4ae8c96..8834251 100644 --- a/src/main/java/anticope/rejects/modules/NewChunks.java +++ b/src/main/java/anticope/rejects/modules/NewChunks.java @@ -23,6 +23,8 @@ import java.util.Collections; import java.util.HashSet; import java.util.Set; +import java.util.concurrent.Executor; +import java.util.concurrent.Executors; /* Ported from: https://github.com/BleachDrinker420/BleachHack/blob/master/BleachHack-Fabric-1.16/src/main/java/bleach/hack/module/mods/NewChunks.java @@ -93,6 +95,7 @@ public class NewChunks extends Module { private final Set newChunks = Collections.synchronizedSet(new HashSet<>()); private final Set oldChunks = Collections.synchronizedSet(new HashSet<>()); private static final Direction[] searchDirs = new Direction[] { Direction.EAST, Direction.NORTH, Direction.WEST, Direction.SOUTH, Direction.UP }; + private final Executor taskExecutor = Executors.newSingleThreadExecutor(); public NewChunks() { super(MeteorRejectsAddon.CATEGORY,"new-chunks", "Detects completely new chunks using certain traits of them"); @@ -177,7 +180,7 @@ else if (event.packet instanceof ChunkDataS2CPacket && mc.world != null) { if (!newChunks.contains(pos) && mc.world.getChunkManager().getChunk(packet.getChunkX(), packet.getChunkZ()) == null) { WorldChunk chunk = new WorldChunk(mc.world, pos); try { - chunk.loadFromPacket(packet.getChunkData().getSectionsDataBuf(), new NbtCompound(), packet.getChunkData().getBlockEntities(packet.getChunkX(), packet.getChunkZ())); + taskExecutor.execute(() -> chunk.loadFromPacket(packet.getChunkData().getSectionsDataBuf(), new NbtCompound(), packet.getChunkData().getBlockEntities(packet.getChunkX(), packet.getChunkZ()))); } catch (ArrayIndexOutOfBoundsException e) { return; }