From 2350ba080edc02434281fbf2a0c8112b9890f616 Mon Sep 17 00:00:00 2001 From: Ghzdude <44148655+ghzdude@users.noreply.github.com> Date: Wed, 20 Dec 2023 21:38:55 -0700 Subject: [PATCH] fix energy container not working right on rejoin --- ...etaTileEntityQuantumStorageController.java | 40 +++++++++++++++---- 1 file changed, 33 insertions(+), 7 deletions(-) diff --git a/src/main/java/gregtech/common/metatileentities/storage/MetaTileEntityQuantumStorageController.java b/src/main/java/gregtech/common/metatileentities/storage/MetaTileEntityQuantumStorageController.java index 1471bf90c2f..2266a8108dc 100644 --- a/src/main/java/gregtech/common/metatileentities/storage/MetaTileEntityQuantumStorageController.java +++ b/src/main/java/gregtech/common/metatileentities/storage/MetaTileEntityQuantumStorageController.java @@ -54,7 +54,7 @@ public class MetaTileEntityQuantumStorageController extends MetaTileEntity imple private static final int MAX_DISTANCE_RADIUS = 16; - private IEnergyContainer energyContainer; + private QuantumControllerEnergyContainer energyContainer; /** Somewhat lazily initialized, make sure to call {@code getStorage()} before trying to access anything in this */ private Map>> storageInstances = new HashMap<>(); @@ -244,16 +244,12 @@ public void rebuildNetwork() { if (storage != null) storage.setDisconnected(); } handler.rebuildCache(); + energyContainer.setMaxCapacity(energyConsumption * 16L); markDirty(); } private void reinitializeEnergyContainer() { - long stored = energyContainer == null ? 0L : energyContainer.getEnergyStored(); - - energyContainer = EnergyContainerHandler.receiverContainer(this, this.energyConsumption * 16L, - Integer.MAX_VALUE, Integer.MAX_VALUE); - - if (stored > 0) energyContainer.addEnergy(stored); + energyContainer = new QuantumControllerEnergyContainer(this); } @Override @@ -419,4 +415,34 @@ public int getSlotLimit(int slot) { return getItemHandlers().getSlotLimit(slot); } } + + private static class QuantumControllerEnergyContainer extends EnergyContainerHandler { + + private long maxCapacity = 0; + public QuantumControllerEnergyContainer(MetaTileEntity tileEntity) { + super(tileEntity, Integer.MAX_VALUE, Integer.MAX_VALUE, Integer.MAX_VALUE, 0, 0); + } + + @Override + public long getEnergyCapacity() { + return this.maxCapacity; + } + + protected void setMaxCapacity(long capacity) { + this.maxCapacity = capacity; + } + + @Override + public @NotNull NBTTagCompound serializeNBT() { + var tag = super.serializeNBT(); + tag.setLong("MaxCapacity", this.maxCapacity); + return tag; + } + + @Override + public void deserializeNBT(@NotNull NBTTagCompound compound) { + this.maxCapacity = compound.getLong("MaxCapacity"); + super.deserializeNBT(compound); + } + } }