From a1ea0e922bc55c89f083923565adc35a14caf3d2 Mon Sep 17 00:00:00 2001 From: Thiakil Date: Tue, 24 Dec 2024 09:30:02 +0800 Subject: [PATCH] check old orphan transmitter was valid and remove orphans when invalidating --- .../lib/transmitter/TransmitterNetworkRegistry.java | 11 +++++++++-- 1 file changed, 9 insertions(+), 2 deletions(-) diff --git a/src/main/java/mekanism/common/lib/transmitter/TransmitterNetworkRegistry.java b/src/main/java/mekanism/common/lib/transmitter/TransmitterNetworkRegistry.java index 21cdb09c7c1..e03923e1e7d 100644 --- a/src/main/java/mekanism/common/lib/transmitter/TransmitterNetworkRegistry.java +++ b/src/main/java/mekanism/common/lib/transmitter/TransmitterNetworkRegistry.java @@ -91,7 +91,14 @@ public static void untrackTransmitter(Transmitter transmitter) { } public static void invalidateTransmitter(Transmitter transmitter) { - getInstance().invalidTransmitters.add(transmitter); + TransmitterNetworkRegistry registry = getInstance(); + registry.invalidTransmitters.add(transmitter); + Coord4D coord = transmitter.getTileCoord(); + Transmitter removed = registry.newOrphanTransmitters.remove(coord); + if (removed != null && removed != transmitter) { + Mekanism.logger.error("Different orphan transmitter was registered at location during removal! {}", coord); + registry.newOrphanTransmitters.put(coord, transmitter);//put it back? + } } public static void registerOrphanTransmitter(Transmitter transmitter) { @@ -101,7 +108,7 @@ public static void registerOrphanTransmitter(Transmitter transmitter) { // was in. Coord4D coord = transmitter.getTileCoord(); Transmitter previous = getInstance().newOrphanTransmitters.put(coord, transmitter); - if (previous != null && previous != transmitter) { + if (previous != null && previous != transmitter && previous.isValid()) { Mekanism.logger.error("Different orphan transmitter was already registered at location! {}", coord); } }