From 2379b88c8ac2e87eb50c6a5000e2cac960931fb3 Mon Sep 17 00:00:00 2001 From: Sebastian Hartte Date: Sun, 21 Jul 2024 22:49:29 +0200 Subject: [PATCH] Fix cable unload of already unloaded chunks. --- src/main/java/owmii/powah/block/cable/CableNet.java | 13 +++++++++---- 1 file changed, 9 insertions(+), 4 deletions(-) diff --git a/src/main/java/owmii/powah/block/cable/CableNet.java b/src/main/java/owmii/powah/block/cable/CableNet.java index 5200fb8..4cbd89d 100644 --- a/src/main/java/owmii/powah/block/cable/CableNet.java +++ b/src/main/java/owmii/powah/block/cable/CableNet.java @@ -20,8 +20,6 @@ import org.slf4j.LoggerFactory; public class CableNet { - private static final Logger LOG = LoggerFactory.getLogger(CableNet.class); - // Level -> ChunkPos -> BlockPos -> Tile private static final Map>> loadedCables = new WeakHashMap<>(); @@ -39,12 +37,19 @@ static void addCable(CableTile cable) { } static void removeCable(CableTile cable) { + // No need to repeat this if the cable isn't part of a net anyway + if (cable.net == null) { + return; + } + var levelMap = loadedCables.get(cable.getLevel()); + if (levelMap == null) { + return; // The full-chunk cleanup already took care of the entire level + } var chunkPos = ChunkPos.asLong(cable.getBlockPos()); var chunkMap = levelMap.get(chunkPos); if (chunkMap == null) { - LOG.error("Ignoring to unload cable @ {} since chunk is already gone.", cable.getBlockPos()); - return; + return; // The full-chunk cleanup already took care of the entire chunk } if (chunkMap.remove(cable.getBlockPos().asLong()) != cable) { throw new RuntimeException("Removed wrong cable from position %s".formatted(cable.getBlockPos()));