From 7080c4d3e2df1276ddc5c73444521fdfe3731496 Mon Sep 17 00:00:00 2001 From: Tiger Wang Date: Sat, 10 Apr 2021 17:17:15 +0100 Subject: Hoppers: use 'locked' bit in meta --- .../IncrementalRedstoneSimulator/HopperHandler.h | 19 +++++++++++++++---- 1 file changed, 15 insertions(+), 4 deletions(-) (limited to 'src/Simulator/IncrementalRedstoneSimulator/HopperHandler.h') diff --git a/src/Simulator/IncrementalRedstoneSimulator/HopperHandler.h b/src/Simulator/IncrementalRedstoneSimulator/HopperHandler.h index 379f7c7d8..ca820441c 100644 --- a/src/Simulator/IncrementalRedstoneSimulator/HopperHandler.h +++ b/src/Simulator/IncrementalRedstoneSimulator/HopperHandler.h @@ -24,20 +24,31 @@ namespace HopperHandler { // LOGD("Evaluating holey the hopper (%d %d %d)", a_Position.x, a_Position.y, a_Position.z); - const auto Previous = DataForChunk(a_Chunk).ExchangeUpdateOncePowerData(a_Position, Power); - if (Previous == Power) + const bool ShouldBeLocked = Power != 0; + const bool PreviouslyLocked = (a_Meta & 0x8) == 0x8; + + if (ShouldBeLocked == PreviouslyLocked) { return; } - a_Chunk.DoWithBlockEntityAt(a_Position, [Power](cBlockEntity & a_BlockEntity) + if (ShouldBeLocked) + { + a_Chunk.SetMeta(a_Position, a_Meta | 0x8); + } + else + { + a_Chunk.SetMeta(a_Position, a_Meta & ~0x8); + } + + a_Chunk.DoWithBlockEntityAt(a_Position, [ShouldBeLocked](cBlockEntity & a_BlockEntity) { if (a_BlockEntity.GetBlockType() != E_BLOCK_HOPPER) { return false; } - static_cast(a_BlockEntity).SetLocked(Power != 0); + static_cast(a_BlockEntity).SetLocked(ShouldBeLocked); return false; }); } -- cgit v1.2.3