From 08d12bceb391b101a3048b8a1cdb211fe245afea Mon Sep 17 00:00:00 2001 From: Hacker6329 Date: Sat, 21 Feb 2026 17:35:35 +0100 Subject: [PATCH 1/5] Added zirnox reactor redstone support on/off --- .../com/hbm/blocks/machine/ReactorZirnox.java | 55 ++++++++++++++++++- .../machine/TileEntityReactorZirnox.java | 13 ++++- 2 files changed, 63 insertions(+), 5 deletions(-) diff --git a/src/main/java/com/hbm/blocks/machine/ReactorZirnox.java b/src/main/java/com/hbm/blocks/machine/ReactorZirnox.java index b9b448ef5..b6c8b53cb 100644 --- a/src/main/java/com/hbm/blocks/machine/ReactorZirnox.java +++ b/src/main/java/com/hbm/blocks/machine/ReactorZirnox.java @@ -9,6 +9,7 @@ import com.hbm.tileentity.TileEntityProxyCombo; import com.hbm.tileentity.machine.TileEntityReactorZirnox; import cpw.mods.fml.common.network.internal.FMLNetworkHandler; +import net.minecraft.block.Block; import net.minecraft.block.material.Material; import net.minecraft.entity.player.EntityPlayer; @@ -39,7 +40,7 @@ public class ReactorZirnox extends BlockDummyable { return true; } else if(!player.isSneaking()) { BossSpawnHandler.markFBI(player); - + int[] pos = this.findCore(world, x, y, z); if(pos == null) @@ -54,7 +55,7 @@ public class ReactorZirnox extends BlockDummyable { @Override public int[] getDimensions() { - return new int[] {1, 0, 2, 2, 2, 2,}; + return new int[] {1, 0, 2, 2, 2, 2,}; } @Override @@ -87,4 +88,52 @@ public class ReactorZirnox extends BlockDummyable { this.makeExtra(world, x + dir.offsetX * o, y + 4, z + dir.offsetZ * o); } -} \ No newline at end of file + @Override + public void onNeighborBlockChange(World world, int x, int y, int z, Block neighbor) { + if (world.isRemote) return; + + // 1. Trova il controller + int[] core = this.findCore(world, x, y, z); + if (core == null) return; + + int cx = core[0]; + int cy = core[1]; + int cz = core[2]; + + TileEntity te = world.getTileEntity(cx, cy, cz); + if (!(te instanceof TileEntityReactorZirnox)) return; + + TileEntityReactorZirnox reactor = (TileEntityReactorZirnox) te; + + boolean powered = false; + + // 2. Scansiona la superficie del multiblock 5x5x5 + for (int dx = -2; dx <= 2 && !powered; dx++) { + for (int dy = 0; dy <= 4 && !powered; dy++) { + for (int dz = -2; dz <= 2 && !powered; dz++) { + + // Solo superficie + if (dx == -2 || dx == 2 || + dy == 0 || dy == 4 || + dz == -2 || dz == 2) { + + int sx = cx + dx; + int sy = cy + dy; + int sz = cz + dz; + + if (world.isBlockIndirectlyGettingPowered(sx, sy, sz) || + world.getBlockPowerInput(sx, sy, sz) > 0) { + + powered = true; + break; + } + } + } + } + } + + // 3. Aggiorna la TileEntity + reactor.setRedstonePowered(powered); + } + +} diff --git a/src/main/java/com/hbm/tileentity/machine/TileEntityReactorZirnox.java b/src/main/java/com/hbm/tileentity/machine/TileEntityReactorZirnox.java index a7ec9973f..bcf571225 100644 --- a/src/main/java/com/hbm/tileentity/machine/TileEntityReactorZirnox.java +++ b/src/main/java/com/hbm/tileentity/machine/TileEntityReactorZirnox.java @@ -53,6 +53,7 @@ public class TileEntityReactorZirnox extends TileEntityMachineBase implements IC public int heat; public static final int maxHeat = 100000; + public boolean redstonePowered = false; public int pressure; public static final int maxPressure = 100000; public boolean isOn = false; @@ -85,6 +86,12 @@ public class TileEntityReactorZirnox extends TileEntityMachineBase implements IC carbonDioxide = new FluidTank(Fluids.CARBONDIOXIDE, 16000); water = new FluidTank(Fluids.WATER, 32000); } + public void setRedstonePowered(boolean powered) { + this.redstonePowered = powered; + if (!powered) { + isOn = false; + } + } @Override public String getName() { @@ -176,7 +183,9 @@ public class TileEntityReactorZirnox extends TileEntityMachineBase implements IC public void updateEntity() { if(!worldObj.isRemote) { - + if (redstonePowered) { + isOn = true; + } this.output = 0; if(worldObj.getTotalWorldTime() % 20 == 0) { @@ -429,7 +438,7 @@ public class TileEntityReactorZirnox extends TileEntityMachineBase implements IC @Override public void receiveControl(NBTTagCompound data) { - if(data.hasKey("control")) { + if(data.hasKey("control") && !redstonePowered) { this.isOn = !this.isOn; } From af34fb730ffc7f9dabe3f1c51bb6e003cfb14b63 Mon Sep 17 00:00:00 2001 From: Hacker6329 Date: Sat, 21 Feb 2026 18:31:11 +0100 Subject: [PATCH 2/5] Unitalized comments --- .../java/com/hbm/blocks/machine/ReactorZirnox.java | 14 ++------------ 1 file changed, 2 insertions(+), 12 deletions(-) diff --git a/src/main/java/com/hbm/blocks/machine/ReactorZirnox.java b/src/main/java/com/hbm/blocks/machine/ReactorZirnox.java index b6c8b53cb..41fb57269 100644 --- a/src/main/java/com/hbm/blocks/machine/ReactorZirnox.java +++ b/src/main/java/com/hbm/blocks/machine/ReactorZirnox.java @@ -91,28 +91,20 @@ public class ReactorZirnox extends BlockDummyable { @Override public void onNeighborBlockChange(World world, int x, int y, int z, Block neighbor) { if (world.isRemote) return; - - // 1. Trova il controller int[] core = this.findCore(world, x, y, z); if (core == null) return; - int cx = core[0]; int cy = core[1]; int cz = core[2]; - TileEntity te = world.getTileEntity(cx, cy, cz); if (!(te instanceof TileEntityReactorZirnox)) return; - TileEntityReactorZirnox reactor = (TileEntityReactorZirnox) te; - boolean powered = false; - - // 2. Scansiona la superficie del multiblock 5x5x5 + // 2. Scan multiblock for (int dx = -2; dx <= 2 && !powered; dx++) { for (int dy = 0; dy <= 4 && !powered; dy++) { for (int dz = -2; dz <= 2 && !powered; dz++) { - - // Solo superficie + // Get only surface blocks if (dx == -2 || dx == 2 || dy == 0 || dy == 4 || dz == -2 || dz == 2) { @@ -131,8 +123,6 @@ public class ReactorZirnox extends BlockDummyable { } } } - - // 3. Aggiorna la TileEntity reactor.setRedstonePowered(powered); } From 6be023015f29024e5c36dc59bb2c88a3c0692293 Mon Sep 17 00:00:00 2001 From: Hacker6329 Date: Mon, 23 Feb 2026 18:31:28 +0100 Subject: [PATCH 3/5] Fixed issue: reactor shutting down if not redstone powered and on by GUI in case of block update nearby. Fixed issue: zirnox multiblock not breaking entirely if mined. --- src/main/java/com/hbm/blocks/machine/ReactorZirnox.java | 1 + .../com/hbm/tileentity/machine/TileEntityReactorZirnox.java | 4 ++-- 2 files changed, 3 insertions(+), 2 deletions(-) diff --git a/src/main/java/com/hbm/blocks/machine/ReactorZirnox.java b/src/main/java/com/hbm/blocks/machine/ReactorZirnox.java index 41fb57269..1316a02eb 100644 --- a/src/main/java/com/hbm/blocks/machine/ReactorZirnox.java +++ b/src/main/java/com/hbm/blocks/machine/ReactorZirnox.java @@ -90,6 +90,7 @@ public class ReactorZirnox extends BlockDummyable { @Override public void onNeighborBlockChange(World world, int x, int y, int z, Block neighbor) { + super.onNeighborBlockChange(world, x, y, z, neighbor); if (world.isRemote) return; int[] core = this.findCore(world, x, y, z); if (core == null) return; diff --git a/src/main/java/com/hbm/tileentity/machine/TileEntityReactorZirnox.java b/src/main/java/com/hbm/tileentity/machine/TileEntityReactorZirnox.java index bcf571225..1c54e4f20 100644 --- a/src/main/java/com/hbm/tileentity/machine/TileEntityReactorZirnox.java +++ b/src/main/java/com/hbm/tileentity/machine/TileEntityReactorZirnox.java @@ -87,10 +87,10 @@ public class TileEntityReactorZirnox extends TileEntityMachineBase implements IC water = new FluidTank(Fluids.WATER, 32000); } public void setRedstonePowered(boolean powered) { - this.redstonePowered = powered; - if (!powered) { + if (!powered && this.redstonePowered) { isOn = false; } + this.redstonePowered = powered; } @Override From 36a39b09e4e87be229d2cb2926cbb7fb327f9ae5 Mon Sep 17 00:00:00 2001 From: Hacker6329 Date: Mon, 23 Feb 2026 18:44:56 +0100 Subject: [PATCH 4/5] Fixed issue: redstonePowered state not saved in nbt --- .../com/hbm/tileentity/machine/TileEntityReactorZirnox.java | 2 ++ 1 file changed, 2 insertions(+) diff --git a/src/main/java/com/hbm/tileentity/machine/TileEntityReactorZirnox.java b/src/main/java/com/hbm/tileentity/machine/TileEntityReactorZirnox.java index 1c54e4f20..f2b93ff1a 100644 --- a/src/main/java/com/hbm/tileentity/machine/TileEntityReactorZirnox.java +++ b/src/main/java/com/hbm/tileentity/machine/TileEntityReactorZirnox.java @@ -122,6 +122,7 @@ public class TileEntityReactorZirnox extends TileEntityMachineBase implements IC steam.readFromNBT(nbt, "steam"); carbonDioxide.readFromNBT(nbt, "carbondioxide"); water.readFromNBT(nbt, "water"); + redstonePowered = nbt.getBoolean("redstonePowered"); } @Override @@ -133,6 +134,7 @@ public class TileEntityReactorZirnox extends TileEntityMachineBase implements IC steam.writeToNBT(nbt, "steam"); carbonDioxide.writeToNBT(nbt, "carbondioxide"); water.writeToNBT(nbt, "water"); + nbt.setBoolean("redstonePowered", redstonePowered); } From 2313cd3b44974a21543ed7c6e620da9000d308bb Mon Sep 17 00:00:00 2001 From: Hacker6329 Date: Mon, 23 Feb 2026 18:56:32 +0100 Subject: [PATCH 5/5] Fixed issue: redstonePowered state not being serialized/deserialized --- .../com/hbm/tileentity/machine/TileEntityReactorZirnox.java | 2 ++ 1 file changed, 2 insertions(+) diff --git a/src/main/java/com/hbm/tileentity/machine/TileEntityReactorZirnox.java b/src/main/java/com/hbm/tileentity/machine/TileEntityReactorZirnox.java index f2b93ff1a..fe412b503 100644 --- a/src/main/java/com/hbm/tileentity/machine/TileEntityReactorZirnox.java +++ b/src/main/java/com/hbm/tileentity/machine/TileEntityReactorZirnox.java @@ -239,6 +239,7 @@ public class TileEntityReactorZirnox extends TileEntityMachineBase implements IC buf.writeInt(this.heat); buf.writeInt(this.pressure); buf.writeBoolean(this.isOn); + buf.writeBoolean(this.redstonePowered); steam.serialize(buf); carbonDioxide.serialize(buf); water.serialize(buf); @@ -250,6 +251,7 @@ public class TileEntityReactorZirnox extends TileEntityMachineBase implements IC this.heat = buf.readInt(); this.pressure = buf.readInt(); this.isOn = buf.readBoolean(); + this.redstonePowered = buf.readBoolean(); steam.deserialize(buf); carbonDioxide.deserialize(buf); water.deserialize(buf);