From a1cc6d20b7c5e1700b830144ae21edf619153a87 Mon Sep 17 00:00:00 2001 From: raoulvdberge Date: Sun, 18 Feb 2024 18:33:06 +0100 Subject: [PATCH 1/3] fix: losing disk when using wrench dismantling on the portable grid --- CHANGELOG.md | 4 ++ .../AbstractPortableGridBlockEntity.java | 24 ++++++-- .../portablegrid/PortableGridBlockItem.java | 55 ++++++++----------- .../PortableGridLootItemFunction.java | 6 +- 4 files changed, 50 insertions(+), 39 deletions(-) diff --git a/CHANGELOG.md b/CHANGELOG.md index 9f0b305d2..0d7e208bb 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -7,6 +7,10 @@ to [Semantic Versioning](https://semver.org/spec/v2.0.0.html). ## [Unreleased] +### Fixed + +- Fixed losing disk when using Wrench dismantling on the Portable Grid. + ## [2.0.0-milestone.3.3] - 2024-02-17 ### Added diff --git a/refinedstorage2-platform-common/src/main/java/com/refinedmods/refinedstorage2/platform/common/storage/portablegrid/AbstractPortableGridBlockEntity.java b/refinedstorage2-platform-common/src/main/java/com/refinedmods/refinedstorage2/platform/common/storage/portablegrid/AbstractPortableGridBlockEntity.java index 64ab1e085..ec53ef457 100644 --- a/refinedstorage2-platform-common/src/main/java/com/refinedmods/refinedstorage2/platform/common/storage/portablegrid/AbstractPortableGridBlockEntity.java +++ b/refinedstorage2-platform-common/src/main/java/com/refinedmods/refinedstorage2/platform/common/storage/portablegrid/AbstractPortableGridBlockEntity.java @@ -34,6 +34,7 @@ import net.minecraft.server.level.ServerPlayer; import net.minecraft.world.entity.player.Inventory; import net.minecraft.world.entity.player.Player; +import net.minecraft.world.item.ItemStack; import net.minecraft.world.level.Level; import net.minecraft.world.level.block.entity.BlockEntity; import net.minecraft.world.level.block.entity.BlockEntityType; @@ -75,6 +76,23 @@ public boolean isGridActive() { }; } + static void readDiskInventory(final CompoundTag tag, final DiskInventory diskInventory) { + if (tag.contains(TAG_DISK_INVENTORY)) { + ContainerUtil.read(tag.getCompound(TAG_DISK_INVENTORY), diskInventory); + } + } + + static void writeDiskInventory(final CompoundTag tag, final DiskInventory diskInventory) { + tag.put(TAG_DISK_INVENTORY, ContainerUtil.write(diskInventory)); + } + + static ItemStack getDisk(final CompoundTag tag) { + if (!tag.contains(TAG_DISK_INVENTORY)) { + return ItemStack.EMPTY; + } + return ContainerUtil.getItemInSlot(tag.getCompound(TAG_DISK_INVENTORY), 0); + } + private static EnergyStorage createEnergyStorage(final PortableGridType type, final BlockEntity blockEntity) { if (type == PortableGridType.CREATIVE) { return CreativeEnergyStorage.INSTANCE; @@ -137,9 +155,7 @@ private void initialize(final Level level) { @Override public void load(final CompoundTag tag) { fromClientTag(tag); - if (tag.contains(TAG_DISK_INVENTORY)) { - ContainerUtil.read(tag.getCompound(TAG_DISK_INVENTORY), diskInventory); - } + readDiskInventory(tag, diskInventory); if (tag.contains(TAG_STORED)) { energyStorage.receive(tag.getLong(TAG_STORED), Action.EXECUTE); } @@ -169,7 +185,7 @@ protected void onClientDriveStateUpdated() { @Override public void saveAdditional(final CompoundTag tag) { super.saveAdditional(tag); - tag.put(TAG_DISK_INVENTORY, ContainerUtil.write(diskInventory)); + writeDiskInventory(tag, diskInventory); tag.putLong(TAG_STORED, energyStorage.getStored()); writeConfiguration(tag); } diff --git a/refinedstorage2-platform-common/src/main/java/com/refinedmods/refinedstorage2/platform/common/storage/portablegrid/PortableGridBlockItem.java b/refinedstorage2-platform-common/src/main/java/com/refinedmods/refinedstorage2/platform/common/storage/portablegrid/PortableGridBlockItem.java index 879c85d66..ecd46232b 100644 --- a/refinedstorage2-platform-common/src/main/java/com/refinedmods/refinedstorage2/platform/common/storage/portablegrid/PortableGridBlockItem.java +++ b/refinedstorage2-platform-common/src/main/java/com/refinedmods/refinedstorage2/platform/common/storage/portablegrid/PortableGridBlockItem.java @@ -12,15 +12,15 @@ import com.refinedmods.refinedstorage2.platform.api.support.energy.AbstractEnergyBlockItem; import com.refinedmods.refinedstorage2.platform.api.support.network.bounditem.SlotReference; import com.refinedmods.refinedstorage2.platform.common.Platform; +import com.refinedmods.refinedstorage2.platform.common.content.BlockEntities; import com.refinedmods.refinedstorage2.platform.common.storage.Disk; import com.refinedmods.refinedstorage2.platform.common.storage.DiskInventory; import com.refinedmods.refinedstorage2.platform.common.support.energy.CreativeEnergyStorage; import com.refinedmods.refinedstorage2.platform.common.support.energy.ItemEnergyStorage; -import com.refinedmods.refinedstorage2.platform.common.util.ContainerUtil; import javax.annotation.Nullable; -import net.minecraft.core.BlockPos; +import net.minecraft.nbt.CompoundTag; import net.minecraft.server.level.ServerPlayer; import net.minecraft.world.InteractionHand; import net.minecraft.world.InteractionResultHolder; @@ -29,11 +29,8 @@ import net.minecraft.world.item.ItemStack; import net.minecraft.world.level.Level; import net.minecraft.world.level.block.Block; -import net.minecraft.world.level.block.state.BlockState; public class PortableGridBlockItem extends AbstractEnergyBlockItem { - private static final String TAG_DISK_INVENTORY = "diskinv"; - private final PortableGridType type; public PortableGridBlockItem(final Block block, final PortableGridType type) { @@ -43,8 +40,7 @@ public PortableGridBlockItem(final Block block, final PortableGridType type) { public static PortableGridBlockItemRenderInfo getRenderInfo(final ItemStack stack, @Nullable final Level level) { - final boolean creative = stack.getItem() instanceof PortableGridBlockItem portableGridBlockItem - && portableGridBlockItem.type == PortableGridType.CREATIVE; + final boolean creative = isCreative(stack); final boolean hasEnergy = creative || ItemEnergyStorage.getStored(stack) > 0; final ItemStack diskStack = getDisk(stack); final boolean active = hasEnergy && !diskStack.isEmpty(); @@ -55,6 +51,11 @@ public static PortableGridBlockItemRenderInfo getRenderInfo(final ItemStack stac return new PortableGridBlockItemRenderInfo(active, disk); } + private static boolean isCreative(final ItemStack stack) { + return stack.getItem() instanceof PortableGridBlockItem portableGridBlockItem + && portableGridBlockItem.type == PortableGridType.CREATIVE; + } + private static StorageState getState(final ItemStack diskStack, final boolean active, @Nullable final Level level) { @@ -71,17 +72,23 @@ private static StorageState getState(final ItemStack diskStack, } private static ItemStack getDisk(final ItemStack stack) { - if (stack.getTag() == null) { - return ItemStack.EMPTY; - } - if (!stack.getTag().contains(TAG_DISK_INVENTORY)) { + final CompoundTag tag = getBlockEntityData(stack); + if (tag == null) { return ItemStack.EMPTY; } - return ContainerUtil.getItemInSlot(stack.getTag().getCompound(TAG_DISK_INVENTORY), 0); + return AbstractPortableGridBlockEntity.getDisk(tag); } static void setDiskInventory(final ItemStack stack, final DiskInventory diskInventory) { - stack.getOrCreateTag().put(TAG_DISK_INVENTORY, ContainerUtil.write(diskInventory)); + final CompoundTag tag = new CompoundTag(); + AbstractPortableGridBlockEntity.writeDiskInventory(tag, diskInventory); + setBlockEntityData( + stack, + isCreative(stack) + ? BlockEntities.INSTANCE.getCreativePortableGrid() + : BlockEntities.INSTANCE.getPortableGrid(), + tag + ); } public EnergyStorage createEnergyStorage(final ItemStack stack) { @@ -91,23 +98,6 @@ public EnergyStorage createEnergyStorage(final ItemStack stack) { return PlatformApi.INSTANCE.asItemEnergyStorage(energyStorage, stack); } - @Override - protected boolean updateCustomBlockEntityTag( - final BlockPos pos, - final Level level, - @Nullable final Player player, - final ItemStack stack, - final BlockState blockState - ) { - final boolean result = super.updateCustomBlockEntityTag(pos, level, player, stack, blockState); - if (!level.isClientSide() - && level.getBlockEntity(pos) instanceof AbstractPortableGridBlockEntity portableGrid) { - final ItemStack diskStack = getDisk(stack); - portableGrid.getDiskInventory().setItem(0, diskStack); - } - return result; - } - @Override public InteractionResultHolder use(final Level level, final Player player, final InteractionHand hand) { final ItemStack stack = player.getItemInHand(hand); @@ -145,8 +135,9 @@ private PortableGridEnergyStorage createEnergyStorageInternal(final ItemStack st private DiskInventory createDiskInventory(final ItemStack stack, final DiskInventoryListenerImpl listener) { final DiskInventory diskInventory = new DiskInventory(listener, 1); - if (stack.getTag() != null && stack.getTag().contains(TAG_DISK_INVENTORY)) { - ContainerUtil.read(stack.getTag().getCompound(TAG_DISK_INVENTORY), diskInventory); + final CompoundTag tag = getBlockEntityData(stack); + if (tag != null) { + AbstractPortableGridBlockEntity.readDiskInventory(tag, diskInventory); } return diskInventory; } diff --git a/refinedstorage2-platform-common/src/main/java/com/refinedmods/refinedstorage2/platform/common/storage/portablegrid/PortableGridLootItemFunction.java b/refinedstorage2-platform-common/src/main/java/com/refinedmods/refinedstorage2/platform/common/storage/portablegrid/PortableGridLootItemFunction.java index d6335c96c..941eef37d 100644 --- a/refinedstorage2-platform-common/src/main/java/com/refinedmods/refinedstorage2/platform/common/storage/portablegrid/PortableGridLootItemFunction.java +++ b/refinedstorage2-platform-common/src/main/java/com/refinedmods/refinedstorage2/platform/common/storage/portablegrid/PortableGridLootItemFunction.java @@ -1,15 +1,15 @@ package com.refinedmods.refinedstorage2.platform.common.storage.portablegrid; import com.refinedmods.refinedstorage2.platform.common.content.LootFunctions; +import com.refinedmods.refinedstorage2.platform.common.support.energy.EnergyLootItemFunction; import net.minecraft.world.item.ItemStack; import net.minecraft.world.level.block.entity.BlockEntity; import net.minecraft.world.level.storage.loot.LootContext; -import net.minecraft.world.level.storage.loot.functions.LootItemFunction; import net.minecraft.world.level.storage.loot.functions.LootItemFunctionType; import net.minecraft.world.level.storage.loot.parameters.LootContextParams; -public class PortableGridLootItemFunction implements LootItemFunction { +public class PortableGridLootItemFunction extends EnergyLootItemFunction { @Override public LootItemFunctionType getType() { return LootFunctions.INSTANCE.getPortableGrid(); @@ -21,6 +21,6 @@ public ItemStack apply(final ItemStack itemStack, final LootContext lootContext) if (blockEntity instanceof AbstractPortableGridBlockEntity portableGrid) { PortableGridBlockItem.setDiskInventory(itemStack, portableGrid.getDiskInventory()); } - return itemStack; + return super.apply(itemStack, lootContext); } } From 3c6874be6fecf7ab447837a25bf59433cc72f459 Mon Sep 17 00:00:00 2001 From: raoulvdberge Date: Mon, 19 Feb 2024 18:02:46 +0100 Subject: [PATCH 2/3] fix: losing energy when using wrench dismantling --- CHANGELOG.md | 1 + .../platform/api/PlatformApi.java | 7 ++ .../platform/api/PlatformApiProxy.java | 8 +++ .../platform/common/PlatformApiImpl.java | 9 +++ .../controller/ControllerBlockEntity.java | 9 +-- .../controller/ControllerBlockItem.java | 7 +- .../AbstractPortableGridBlockEntity.java | 9 +-- .../portablegrid/PortableGridBlockItem.java | 11 ++-- .../energy/ItemBlockEnergyStorage.java | 65 +++++++++++++++++++ .../support/energy/ItemEnergyStorage.java | 37 +++++------ .../platform/fabric/ModInitializerImpl.java | 2 +- .../platform/forge/ModInitializer.java | 2 +- 12 files changed, 126 insertions(+), 41 deletions(-) create mode 100644 refinedstorage2-platform-common/src/main/java/com/refinedmods/refinedstorage2/platform/common/support/energy/ItemBlockEnergyStorage.java diff --git a/CHANGELOG.md b/CHANGELOG.md index 0d7e208bb..538735bca 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -10,6 +10,7 @@ to [Semantic Versioning](https://semver.org/spec/v2.0.0.html). ### Fixed - Fixed losing disk when using Wrench dismantling on the Portable Grid. +- Fixed losing energy when using Wrench dismantling on the Portable Grid and the Controller. ## [2.0.0-milestone.3.3] - 2024-02-17 diff --git a/refinedstorage2-platform-api/src/main/java/com/refinedmods/refinedstorage2/platform/api/PlatformApi.java b/refinedstorage2-platform-api/src/main/java/com/refinedmods/refinedstorage2/platform/api/PlatformApi.java index 72e3cf9f6..6f3c71781 100644 --- a/refinedstorage2-platform-api/src/main/java/com/refinedmods/refinedstorage2/platform/api/PlatformApi.java +++ b/refinedstorage2-platform-api/src/main/java/com/refinedmods/refinedstorage2/platform/api/PlatformApi.java @@ -53,6 +53,7 @@ import net.minecraft.world.item.Item; import net.minecraft.world.item.ItemStack; import net.minecraft.world.level.Level; +import net.minecraft.world.level.block.entity.BlockEntityType; import org.apiguardian.api.API; @API(status = API.Status.STABLE, since = "2.0.0-milestone.1.0") @@ -165,6 +166,12 @@ GridScrollingStrategy createGridScrollingStrategy(AbstractContainerMenu containe EnergyStorage asItemEnergyStorage(EnergyStorage energyStorage, ItemStack stack); + EnergyStorage asBlockItemEnergyStorage( + EnergyStorage energyStorage, + ItemStack stack, + BlockEntityType blockEntityType + ); + NetworkBoundItemHelper getNetworkBoundItemHelper(); PlatformRegistry getSlotReferenceFactoryRegistry(); diff --git a/refinedstorage2-platform-api/src/main/java/com/refinedmods/refinedstorage2/platform/api/PlatformApiProxy.java b/refinedstorage2-platform-api/src/main/java/com/refinedmods/refinedstorage2/platform/api/PlatformApiProxy.java index 9820d7009..de1375c99 100644 --- a/refinedstorage2-platform-api/src/main/java/com/refinedmods/refinedstorage2/platform/api/PlatformApiProxy.java +++ b/refinedstorage2-platform-api/src/main/java/com/refinedmods/refinedstorage2/platform/api/PlatformApiProxy.java @@ -54,6 +54,7 @@ import net.minecraft.world.item.Item; import net.minecraft.world.item.ItemStack; import net.minecraft.world.level.Level; +import net.minecraft.world.level.block.entity.BlockEntityType; public class PlatformApiProxy implements PlatformApi { @Nullable @@ -324,6 +325,13 @@ public EnergyStorage asItemEnergyStorage(final EnergyStorage energyStorage, fina return ensureLoaded().asItemEnergyStorage(energyStorage, stack); } + @Override + public EnergyStorage asBlockItemEnergyStorage(final EnergyStorage energyStorage, + final ItemStack stack, + final BlockEntityType blockEntityType) { + return ensureLoaded().asBlockItemEnergyStorage(energyStorage, stack, blockEntityType); + } + @Override public NetworkBoundItemHelper getNetworkBoundItemHelper() { return ensureLoaded().getNetworkBoundItemHelper(); diff --git a/refinedstorage2-platform-common/src/main/java/com/refinedmods/refinedstorage2/platform/common/PlatformApiImpl.java b/refinedstorage2-platform-common/src/main/java/com/refinedmods/refinedstorage2/platform/common/PlatformApiImpl.java index de8798b0a..4049dbff1 100644 --- a/refinedstorage2-platform-common/src/main/java/com/refinedmods/refinedstorage2/platform/common/PlatformApiImpl.java +++ b/refinedstorage2-platform-common/src/main/java/com/refinedmods/refinedstorage2/platform/common/PlatformApiImpl.java @@ -61,6 +61,7 @@ import com.refinedmods.refinedstorage2.platform.common.storagemonitor.CompositeStorageMonitorExtractionStrategy; import com.refinedmods.refinedstorage2.platform.common.storagemonitor.CompositeStorageMonitorInsertionStrategy; import com.refinedmods.refinedstorage2.platform.common.support.energy.EnergyItemHelperImpl; +import com.refinedmods.refinedstorage2.platform.common.support.energy.ItemBlockEnergyStorage; import com.refinedmods.refinedstorage2.platform.common.support.energy.ItemEnergyStorage; import com.refinedmods.refinedstorage2.platform.common.support.network.ConnectionProviderImpl; import com.refinedmods.refinedstorage2.platform.common.support.network.bounditem.CompositeSlotReferenceProvider; @@ -101,6 +102,7 @@ import net.minecraft.world.item.Item; import net.minecraft.world.item.ItemStack; import net.minecraft.world.level.Level; +import net.minecraft.world.level.block.entity.BlockEntityType; import net.minecraft.world.level.saveddata.SavedData; import static com.refinedmods.refinedstorage2.platform.common.util.IdentifierUtil.createIdentifier; @@ -468,6 +470,13 @@ public EnergyStorage asItemEnergyStorage(final EnergyStorage energyStorage, return new ItemEnergyStorage(stack, energyStorage); } + @Override + public EnergyStorage asBlockItemEnergyStorage(final EnergyStorage energyStorage, + final ItemStack stack, + final BlockEntityType blockEntityType) { + return new ItemBlockEnergyStorage(energyStorage, stack, blockEntityType); + } + @Override public NetworkBoundItemHelper getNetworkBoundItemHelper() { return networkBoundItemHelper; diff --git a/refinedstorage2-platform-common/src/main/java/com/refinedmods/refinedstorage2/platform/common/controller/ControllerBlockEntity.java b/refinedstorage2-platform-common/src/main/java/com/refinedmods/refinedstorage2/platform/common/controller/ControllerBlockEntity.java index fc7d3e72d..a98759460 100644 --- a/refinedstorage2-platform-common/src/main/java/com/refinedmods/refinedstorage2/platform/common/controller/ControllerBlockEntity.java +++ b/refinedstorage2-platform-common/src/main/java/com/refinedmods/refinedstorage2/platform/common/controller/ControllerBlockEntity.java @@ -1,6 +1,5 @@ package com.refinedmods.refinedstorage2.platform.common.controller; -import com.refinedmods.refinedstorage2.api.core.Action; import com.refinedmods.refinedstorage2.api.network.energy.EnergyStorage; import com.refinedmods.refinedstorage2.api.network.impl.node.controller.ControllerNetworkNode; import com.refinedmods.refinedstorage2.platform.api.support.energy.TransferableBlockEntityEnergy; @@ -10,6 +9,7 @@ import com.refinedmods.refinedstorage2.platform.common.support.containermenu.ExtendedMenuProvider; import com.refinedmods.refinedstorage2.platform.common.support.energy.BlockEntityEnergyStorage; import com.refinedmods.refinedstorage2.platform.common.support.energy.CreativeEnergyStorage; +import com.refinedmods.refinedstorage2.platform.common.support.energy.ItemBlockEnergyStorage; import com.refinedmods.refinedstorage2.platform.common.support.network.AbstractRedstoneModeNetworkNodeContainerBlockEntity; import com.google.common.util.concurrent.RateLimiter; @@ -31,7 +31,6 @@ public class ControllerBlockEntity extends AbstractRedstoneModeNetworkNodeContai implements ExtendedMenuProvider, TransferableBlockEntityEnergy { private static final Logger LOGGER = LoggerFactory.getLogger(ControllerBlockEntity.class); - private static final String TAG_STORED = "stored"; private static final String TAG_CAPACITY = "capacity"; private final ControllerType type; @@ -78,7 +77,7 @@ public void updateEnergyTypeInLevel(final BlockState state) { @Override public void saveAdditional(final CompoundTag tag) { super.saveAdditional(tag); - tag.putLong(TAG_STORED, getNode().getActualStored()); + ItemBlockEnergyStorage.writeToTag(tag, getNode().getActualStored()); saveRenderingInfo(tag); } @@ -89,9 +88,7 @@ private void saveRenderingInfo(final CompoundTag tag) { @Override public void load(final CompoundTag tag) { super.load(tag); - if (tag.contains(TAG_STORED)) { - energyStorage.receive(tag.getLong(TAG_STORED), Action.EXECUTE); - } + ItemBlockEnergyStorage.readFromTag(energyStorage, tag); } @Override diff --git a/refinedstorage2-platform-common/src/main/java/com/refinedmods/refinedstorage2/platform/common/controller/ControllerBlockItem.java b/refinedstorage2-platform-common/src/main/java/com/refinedmods/refinedstorage2/platform/common/controller/ControllerBlockItem.java index 752f57d1e..d78218c88 100644 --- a/refinedstorage2-platform-common/src/main/java/com/refinedmods/refinedstorage2/platform/common/controller/ControllerBlockItem.java +++ b/refinedstorage2-platform-common/src/main/java/com/refinedmods/refinedstorage2/platform/common/controller/ControllerBlockItem.java @@ -6,6 +6,7 @@ import com.refinedmods.refinedstorage2.platform.api.support.HelpTooltipComponent; import com.refinedmods.refinedstorage2.platform.api.support.energy.AbstractEnergyBlockItem; import com.refinedmods.refinedstorage2.platform.common.Platform; +import com.refinedmods.refinedstorage2.platform.common.content.BlockEntities; import java.util.Optional; @@ -44,6 +45,10 @@ public EnergyStorage createEnergyStorage(final ItemStack stack) { final EnergyStorage energyStorage = new EnergyStorageImpl( Platform.INSTANCE.getConfig().getController().getEnergyCapacity() ); - return PlatformApi.INSTANCE.asItemEnergyStorage(energyStorage, stack); + return PlatformApi.INSTANCE.asBlockItemEnergyStorage( + energyStorage, + stack, + BlockEntities.INSTANCE.getController() + ); } } diff --git a/refinedstorage2-platform-common/src/main/java/com/refinedmods/refinedstorage2/platform/common/storage/portablegrid/AbstractPortableGridBlockEntity.java b/refinedstorage2-platform-common/src/main/java/com/refinedmods/refinedstorage2/platform/common/storage/portablegrid/AbstractPortableGridBlockEntity.java index ec53ef457..8726ae356 100644 --- a/refinedstorage2-platform-common/src/main/java/com/refinedmods/refinedstorage2/platform/common/storage/portablegrid/AbstractPortableGridBlockEntity.java +++ b/refinedstorage2-platform-common/src/main/java/com/refinedmods/refinedstorage2/platform/common/storage/portablegrid/AbstractPortableGridBlockEntity.java @@ -1,6 +1,5 @@ package com.refinedmods.refinedstorage2.platform.common.storage.portablegrid; -import com.refinedmods.refinedstorage2.api.core.Action; import com.refinedmods.refinedstorage2.api.network.energy.EnergyStorage; import com.refinedmods.refinedstorage2.platform.api.PlatformApi; import com.refinedmods.refinedstorage2.platform.api.configurationcard.ConfigurationCardTarget; @@ -18,6 +17,7 @@ import com.refinedmods.refinedstorage2.platform.common.support.containermenu.ExtendedMenuProvider; import com.refinedmods.refinedstorage2.platform.common.support.energy.BlockEntityEnergyStorage; import com.refinedmods.refinedstorage2.platform.common.support.energy.CreativeEnergyStorage; +import com.refinedmods.refinedstorage2.platform.common.support.energy.ItemBlockEnergyStorage; import com.refinedmods.refinedstorage2.platform.common.util.ContainerUtil; import javax.annotation.Nullable; @@ -48,7 +48,6 @@ public abstract class AbstractPortableGridBlockEntity extends BlockEntity implem private static final String TAG_DISK_INVENTORY = "inv"; private static final String TAG_DISKS = "disks"; - private static final String TAG_STORED = "stored"; private static final String TAG_REDSTONE_MODE = "rm"; @Nullable @@ -156,9 +155,7 @@ private void initialize(final Level level) { public void load(final CompoundTag tag) { fromClientTag(tag); readDiskInventory(tag, diskInventory); - if (tag.contains(TAG_STORED)) { - energyStorage.receive(tag.getLong(TAG_STORED), Action.EXECUTE); - } + ItemBlockEnergyStorage.readFromTag(energyStorage, tag); readConfiguration(tag); super.load(tag); } @@ -186,7 +183,7 @@ protected void onClientDriveStateUpdated() { public void saveAdditional(final CompoundTag tag) { super.saveAdditional(tag); writeDiskInventory(tag, diskInventory); - tag.putLong(TAG_STORED, energyStorage.getStored()); + ItemBlockEnergyStorage.writeToTag(tag, energyStorage.getStored()); writeConfiguration(tag); } diff --git a/refinedstorage2-platform-common/src/main/java/com/refinedmods/refinedstorage2/platform/common/storage/portablegrid/PortableGridBlockItem.java b/refinedstorage2-platform-common/src/main/java/com/refinedmods/refinedstorage2/platform/common/storage/portablegrid/PortableGridBlockItem.java index ecd46232b..8090bf465 100644 --- a/refinedstorage2-platform-common/src/main/java/com/refinedmods/refinedstorage2/platform/common/storage/portablegrid/PortableGridBlockItem.java +++ b/refinedstorage2-platform-common/src/main/java/com/refinedmods/refinedstorage2/platform/common/storage/portablegrid/PortableGridBlockItem.java @@ -16,7 +16,6 @@ import com.refinedmods.refinedstorage2.platform.common.storage.Disk; import com.refinedmods.refinedstorage2.platform.common.storage.DiskInventory; import com.refinedmods.refinedstorage2.platform.common.support.energy.CreativeEnergyStorage; -import com.refinedmods.refinedstorage2.platform.common.support.energy.ItemEnergyStorage; import javax.annotation.Nullable; @@ -41,7 +40,7 @@ public PortableGridBlockItem(final Block block, final PortableGridType type) { public static PortableGridBlockItemRenderInfo getRenderInfo(final ItemStack stack, @Nullable final Level level) { final boolean creative = isCreative(stack); - final boolean hasEnergy = creative || ItemEnergyStorage.getStored(stack) > 0; + final boolean hasEnergy = creative || createEnergyStorage(stack).getStored() > 0; final ItemStack diskStack = getDisk(stack); final boolean active = hasEnergy && !diskStack.isEmpty(); final Disk disk = new Disk( @@ -91,11 +90,15 @@ static void setDiskInventory(final ItemStack stack, final DiskInventory diskInve ); } - public EnergyStorage createEnergyStorage(final ItemStack stack) { + public static EnergyStorage createEnergyStorage(final ItemStack stack) { final EnergyStorage energyStorage = new EnergyStorageImpl( Platform.INSTANCE.getConfig().getPortableGrid().getEnergyCapacity() ); - return PlatformApi.INSTANCE.asItemEnergyStorage(energyStorage, stack); + return PlatformApi.INSTANCE.asBlockItemEnergyStorage( + energyStorage, + stack, + BlockEntities.INSTANCE.getPortableGrid() + ); } @Override diff --git a/refinedstorage2-platform-common/src/main/java/com/refinedmods/refinedstorage2/platform/common/support/energy/ItemBlockEnergyStorage.java b/refinedstorage2-platform-common/src/main/java/com/refinedmods/refinedstorage2/platform/common/support/energy/ItemBlockEnergyStorage.java new file mode 100644 index 000000000..3756d2955 --- /dev/null +++ b/refinedstorage2-platform-common/src/main/java/com/refinedmods/refinedstorage2/platform/common/support/energy/ItemBlockEnergyStorage.java @@ -0,0 +1,65 @@ +package com.refinedmods.refinedstorage2.platform.common.support.energy; + +import com.refinedmods.refinedstorage2.api.core.Action; +import com.refinedmods.refinedstorage2.api.network.energy.EnergyStorage; +import com.refinedmods.refinedstorage2.api.network.impl.energy.AbstractProxyEnergyStorage; + +import net.minecraft.nbt.CompoundTag; +import net.minecraft.world.item.BlockItem; +import net.minecraft.world.item.ItemStack; +import net.minecraft.world.level.block.entity.BlockEntityType; + +public class ItemBlockEnergyStorage extends AbstractProxyEnergyStorage { + private static final String TAG_STORED = "stored"; + + private final ItemStack stack; + private final BlockEntityType blockEntityType; + + public ItemBlockEnergyStorage(final EnergyStorage energyStorage, + final ItemStack stack, + final BlockEntityType blockEntityType) { + super(energyStorage); + this.stack = stack; + this.blockEntityType = blockEntityType; + final CompoundTag tag = BlockItem.getBlockEntityData(stack); + if (tag != null) { + readFromTag(energyStorage, tag); + } + } + + @Override + public long receive(final long amount, final Action action) { + final long received = super.receive(amount, action); + if (received > 0 && action == Action.EXECUTE) { + updateStored(); + } + return received; + } + + @Override + public long extract(final long amount, final Action action) { + final long extracted = super.extract(amount, action); + if (extracted > 0 && action == Action.EXECUTE) { + updateStored(); + } + return extracted; + } + + private void updateStored() { + CompoundTag tag = BlockItem.getBlockEntityData(stack); + if (tag == null) { + tag = new CompoundTag(); + } + writeToTag(tag, getStored()); + BlockItem.setBlockEntityData(stack, blockEntityType, tag); + } + + public static void writeToTag(final CompoundTag tag, final long stored) { + tag.putLong(TAG_STORED, stored); + } + + public static void readFromTag(final EnergyStorage energyStorage, final CompoundTag tag) { + final long stored = tag.getLong(TAG_STORED); + energyStorage.receive(stored, Action.EXECUTE); + } +} diff --git a/refinedstorage2-platform-common/src/main/java/com/refinedmods/refinedstorage2/platform/common/support/energy/ItemEnergyStorage.java b/refinedstorage2-platform-common/src/main/java/com/refinedmods/refinedstorage2/platform/common/support/energy/ItemEnergyStorage.java index 47c2adf57..6fd4b568a 100644 --- a/refinedstorage2-platform-common/src/main/java/com/refinedmods/refinedstorage2/platform/common/support/energy/ItemEnergyStorage.java +++ b/refinedstorage2-platform-common/src/main/java/com/refinedmods/refinedstorage2/platform/common/support/energy/ItemEnergyStorage.java @@ -2,50 +2,43 @@ import com.refinedmods.refinedstorage2.api.core.Action; import com.refinedmods.refinedstorage2.api.network.energy.EnergyStorage; +import com.refinedmods.refinedstorage2.api.network.impl.energy.AbstractProxyEnergyStorage; import net.minecraft.world.item.ItemStack; -public class ItemEnergyStorage implements EnergyStorage { +public class ItemEnergyStorage extends AbstractProxyEnergyStorage { private static final String TAG_STORED = "stored"; private final ItemStack stack; - private final EnergyStorage delegate; public ItemEnergyStorage(final ItemStack stack, final EnergyStorage delegate) { + super(delegate); this.stack = stack; - this.delegate = delegate; - delegate.receive(getStored(stack), Action.EXECUTE); - } - - public static long getStored(final ItemStack stack) { - return stack.getTag() != null ? stack.getTag().getLong(TAG_STORED) : 0; - } - - @Override - public long getStored() { - return delegate.getStored(); - } - - @Override - public long getCapacity() { - return delegate.getCapacity(); + final long stored = stack.getTag() != null ? stack.getTag().getLong(TAG_STORED) : 0; + if (stored > 0) { + delegate.receive(stored, Action.EXECUTE); + } } @Override public long receive(final long amount, final Action action) { - final long received = delegate.receive(amount, action); + final long received = super.receive(amount, action); if (received > 0 && action == Action.EXECUTE) { - stack.getOrCreateTag().putLong(TAG_STORED, getStored()); + updateStored(); } return received; } @Override public long extract(final long amount, final Action action) { - final long extracted = delegate.extract(amount, action); + final long extracted = super.extract(amount, action); if (extracted > 0 && action == Action.EXECUTE) { - stack.getOrCreateTag().putLong(TAG_STORED, getStored()); + updateStored(); } return extracted; } + + private void updateStored() { + stack.getOrCreateTag().putLong(TAG_STORED, getStored()); + } } diff --git a/refinedstorage2-platform-fabric/src/main/java/com/refinedmods/refinedstorage2/platform/fabric/ModInitializerImpl.java b/refinedstorage2-platform-fabric/src/main/java/com/refinedmods/refinedstorage2/platform/fabric/ModInitializerImpl.java index 535954036..2a39d003a 100644 --- a/refinedstorage2-platform-fabric/src/main/java/com/refinedmods/refinedstorage2/platform/fabric/ModInitializerImpl.java +++ b/refinedstorage2-platform-fabric/src/main/java/com/refinedmods/refinedstorage2/platform/fabric/ModInitializerImpl.java @@ -370,7 +370,7 @@ private void registerEnergyItemProviders() { controller.get() )); EnergyStorage.ITEM.registerForItems( - (stack, context) -> new EnergyStorageAdapter(Items.INSTANCE.getPortableGrid().createEnergyStorage(stack)), + (stack, context) -> new EnergyStorageAdapter(PortableGridBlockItem.createEnergyStorage(stack)), Items.INSTANCE.getPortableGrid() ); } diff --git a/refinedstorage2-platform-forge/src/main/java/com/refinedmods/refinedstorage2/platform/forge/ModInitializer.java b/refinedstorage2-platform-forge/src/main/java/com/refinedmods/refinedstorage2/platform/forge/ModInitializer.java index a09b377fe..fa72d378f 100644 --- a/refinedstorage2-platform-forge/src/main/java/com/refinedmods/refinedstorage2/platform/forge/ModInitializer.java +++ b/refinedstorage2-platform-forge/src/main/java/com/refinedmods/refinedstorage2/platform/forge/ModInitializer.java @@ -315,7 +315,7 @@ private void registerCapabilities(final RegisterCapabilitiesEvent event) { )); event.registerItem( Capabilities.EnergyStorage.ITEM, - (stack, ctx) -> new EnergyStorageAdapter(Items.INSTANCE.getPortableGrid().createEnergyStorage(stack)), + (stack, ctx) -> new EnergyStorageAdapter(PortableGridBlockItem.createEnergyStorage(stack)), Items.INSTANCE.getPortableGrid() ); } From c4c807a69663b75feda8e1bd63145836b4952e03 Mon Sep 17 00:00:00 2001 From: raoulvdberge Date: Mon, 19 Feb 2024 18:11:17 +0100 Subject: [PATCH 3/3] refactor: use energy proxy for block entity change detection --- .../impl/energy/EnergyStorageImpl.java | 6 ---- .../impl/energy/EnergyStorageImplTest.java | 33 ++----------------- .../controller/ControllerBlockEntity.java | 3 +- .../AbstractPortableGridBlockEntity.java | 3 +- .../energy/BlockEntityEnergyStorage.java | 28 ++++++++++++---- 5 files changed, 27 insertions(+), 46 deletions(-) diff --git a/refinedstorage2-network/src/main/java/com/refinedmods/refinedstorage2/api/network/impl/energy/EnergyStorageImpl.java b/refinedstorage2-network/src/main/java/com/refinedmods/refinedstorage2/api/network/impl/energy/EnergyStorageImpl.java index 829e6eae2..b98e91f2f 100644 --- a/refinedstorage2-network/src/main/java/com/refinedmods/refinedstorage2/api/network/impl/energy/EnergyStorageImpl.java +++ b/refinedstorage2-network/src/main/java/com/refinedmods/refinedstorage2/api/network/impl/energy/EnergyStorageImpl.java @@ -32,7 +32,6 @@ public long receive(final long amount, final Action action) { final long maxReceive = Math.min(amount, spaceRemaining); if (maxReceive > 0 && action == Action.EXECUTE) { stored += maxReceive; - changed(); } return maxReceive; } @@ -42,12 +41,7 @@ public long extract(final long amount, final Action action) { final long maxExtract = Math.min(stored, amount); if (maxExtract > 0 && action == Action.EXECUTE) { stored -= maxExtract; - changed(); } return maxExtract; } - - protected void changed() { - // no op - } } diff --git a/refinedstorage2-network/src/test/java/com/refinedmods/refinedstorage2/api/network/impl/energy/EnergyStorageImplTest.java b/refinedstorage2-network/src/test/java/com/refinedmods/refinedstorage2/api/network/impl/energy/EnergyStorageImplTest.java index fa043eb9b..558600c51 100644 --- a/refinedstorage2-network/src/test/java/com/refinedmods/refinedstorage2/api/network/impl/energy/EnergyStorageImplTest.java +++ b/refinedstorage2-network/src/test/java/com/refinedmods/refinedstorage2/api/network/impl/energy/EnergyStorageImplTest.java @@ -14,18 +14,10 @@ class EnergyStorageImplTest { EnergyStorage sut; - int changeCount; @BeforeEach void setUp() { - changeCount = 0; - sut = new EnergyStorageImpl(100) { - @Override - protected void changed() { - super.changed(); - changeCount++; - } - }; + sut = new EnergyStorageImpl(100); } @Test @@ -41,20 +33,13 @@ void testInvalidCapacity() { @EnumSource(Action.class) void shouldNotReceiveEnergyOnZeroCapacityStorage(final Action action) { // Arrange - final EnergyStorage zeroCapacitySut = new EnergyStorageImpl(0) { - @Override - protected void changed() { - super.changed(); - changeCount++; - } - }; + final EnergyStorage zeroCapacitySut = new EnergyStorageImpl(0); // Act final long inserted = zeroCapacitySut.receive(1, action); // Assert assertThat(inserted).isZero(); - assertThat(changeCount).isZero(); assertThat(zeroCapacitySut.getStored()).isZero(); } @@ -69,10 +54,8 @@ void shouldReceiveEnergy(final Action action) { if (action == Action.EXECUTE) { assertThat(sut.getStored()).isEqualTo(50); - assertThat(changeCount).isEqualTo(1); } else { assertThat(sut.getStored()).isZero(); - assertThat(changeCount).isZero(); } } @@ -87,10 +70,8 @@ void shouldReceiveEnergyAndReachCapacity(final Action action) { if (action == Action.EXECUTE) { assertThat(sut.getStored()).isEqualTo(100); - assertThat(changeCount).isEqualTo(1); } else { assertThat(sut.getStored()).isZero(); - assertThat(changeCount).isZero(); } } @@ -105,10 +86,8 @@ void shouldReceiveEnergyAndExceedCapacity(final Action action) { if (action == Action.EXECUTE) { assertThat(sut.getStored()).isEqualTo(100); - assertThat(changeCount).isEqualTo(1); } else { assertThat(sut.getStored()).isZero(); - assertThat(changeCount).isZero(); } } @@ -117,14 +96,12 @@ void shouldReceiveEnergyAndExceedCapacity(final Action action) { void shouldNotReceiveEnergyWhenFull(final Action action) { // Arrange sut.receive(100, Action.EXECUTE); - changeCount = 0; // Act final long inserted = sut.receive(100, action); // Assert assertThat(inserted).isZero(); - assertThat(changeCount).isZero(); assertThat(sut.getStored()).isEqualTo(100); } @@ -133,7 +110,6 @@ void shouldNotReceiveEnergyWhenFull(final Action action) { void shouldExtractEnergyPartly(final Action action) { // Arrange sut.receive(100, Action.EXECUTE); - changeCount = 0; // Act final long extracted = sut.extract(99, action); @@ -143,10 +119,8 @@ void shouldExtractEnergyPartly(final Action action) { if (action == Action.EXECUTE) { assertThat(sut.getStored()).isEqualTo(1); - assertThat(changeCount).isEqualTo(1); } else { assertThat(sut.getStored()).isEqualTo(100); - assertThat(changeCount).isZero(); } } @@ -155,7 +129,6 @@ void shouldExtractEnergyPartly(final Action action) { void shouldExtractEnergyCompletely(final Action action) { // Arrange sut.receive(50, Action.EXECUTE); - changeCount = 0; // Act final long extracted = sut.extract(51, action); @@ -165,10 +138,8 @@ void shouldExtractEnergyCompletely(final Action action) { if (action == Action.EXECUTE) { assertThat(sut.getStored()).isZero(); - assertThat(changeCount).isEqualTo(1); } else { assertThat(sut.getStored()).isEqualTo(50); - assertThat(changeCount).isZero(); } } } diff --git a/refinedstorage2-platform-common/src/main/java/com/refinedmods/refinedstorage2/platform/common/controller/ControllerBlockEntity.java b/refinedstorage2-platform-common/src/main/java/com/refinedmods/refinedstorage2/platform/common/controller/ControllerBlockEntity.java index a98759460..ca239b878 100644 --- a/refinedstorage2-platform-common/src/main/java/com/refinedmods/refinedstorage2/platform/common/controller/ControllerBlockEntity.java +++ b/refinedstorage2-platform-common/src/main/java/com/refinedmods/refinedstorage2/platform/common/controller/ControllerBlockEntity.java @@ -1,6 +1,7 @@ package com.refinedmods.refinedstorage2.platform.common.controller; import com.refinedmods.refinedstorage2.api.network.energy.EnergyStorage; +import com.refinedmods.refinedstorage2.api.network.impl.energy.EnergyStorageImpl; import com.refinedmods.refinedstorage2.api.network.impl.node.controller.ControllerNetworkNode; import com.refinedmods.refinedstorage2.platform.api.support.energy.TransferableBlockEntityEnergy; import com.refinedmods.refinedstorage2.platform.common.Platform; @@ -49,7 +50,7 @@ private static EnergyStorage createEnergyStorage(final ControllerType type, fina return CreativeEnergyStorage.INSTANCE; } return new BlockEntityEnergyStorage( - Platform.INSTANCE.getConfig().getController().getEnergyCapacity(), + new EnergyStorageImpl(Platform.INSTANCE.getConfig().getController().getEnergyCapacity()), blockEntity ); } diff --git a/refinedstorage2-platform-common/src/main/java/com/refinedmods/refinedstorage2/platform/common/storage/portablegrid/AbstractPortableGridBlockEntity.java b/refinedstorage2-platform-common/src/main/java/com/refinedmods/refinedstorage2/platform/common/storage/portablegrid/AbstractPortableGridBlockEntity.java index 8726ae356..ab17a63d0 100644 --- a/refinedstorage2-platform-common/src/main/java/com/refinedmods/refinedstorage2/platform/common/storage/portablegrid/AbstractPortableGridBlockEntity.java +++ b/refinedstorage2-platform-common/src/main/java/com/refinedmods/refinedstorage2/platform/common/storage/portablegrid/AbstractPortableGridBlockEntity.java @@ -1,6 +1,7 @@ package com.refinedmods.refinedstorage2.platform.common.storage.portablegrid; import com.refinedmods.refinedstorage2.api.network.energy.EnergyStorage; +import com.refinedmods.refinedstorage2.api.network.impl.energy.EnergyStorageImpl; import com.refinedmods.refinedstorage2.platform.api.PlatformApi; import com.refinedmods.refinedstorage2.platform.api.configurationcard.ConfigurationCardTarget; import com.refinedmods.refinedstorage2.platform.api.grid.Grid; @@ -97,7 +98,7 @@ private static EnergyStorage createEnergyStorage(final PortableGridType type, fi return CreativeEnergyStorage.INSTANCE; } return new BlockEntityEnergyStorage( - Platform.INSTANCE.getConfig().getPortableGrid().getEnergyCapacity(), + new EnergyStorageImpl(Platform.INSTANCE.getConfig().getPortableGrid().getEnergyCapacity()), blockEntity ); } diff --git a/refinedstorage2-platform-common/src/main/java/com/refinedmods/refinedstorage2/platform/common/support/energy/BlockEntityEnergyStorage.java b/refinedstorage2-platform-common/src/main/java/com/refinedmods/refinedstorage2/platform/common/support/energy/BlockEntityEnergyStorage.java index 6515f7ffd..eeb98bd13 100644 --- a/refinedstorage2-platform-common/src/main/java/com/refinedmods/refinedstorage2/platform/common/support/energy/BlockEntityEnergyStorage.java +++ b/refinedstorage2-platform-common/src/main/java/com/refinedmods/refinedstorage2/platform/common/support/energy/BlockEntityEnergyStorage.java @@ -1,20 +1,34 @@ package com.refinedmods.refinedstorage2.platform.common.support.energy; -import com.refinedmods.refinedstorage2.api.network.impl.energy.EnergyStorageImpl; +import com.refinedmods.refinedstorage2.api.core.Action; +import com.refinedmods.refinedstorage2.api.network.energy.EnergyStorage; +import com.refinedmods.refinedstorage2.api.network.impl.energy.AbstractProxyEnergyStorage; import net.minecraft.world.level.block.entity.BlockEntity; -public class BlockEntityEnergyStorage extends EnergyStorageImpl { +public class BlockEntityEnergyStorage extends AbstractProxyEnergyStorage { private final BlockEntity blockEntity; - public BlockEntityEnergyStorage(final long capacity, final BlockEntity blockEntity) { - super(capacity); + public BlockEntityEnergyStorage(final EnergyStorage delegate, final BlockEntity blockEntity) { + super(delegate); this.blockEntity = blockEntity; } @Override - protected void changed() { - super.changed(); - blockEntity.setChanged(); + public long receive(final long amount, final Action action) { + final long received = super.receive(amount, action); + if (received > 0 && action == Action.EXECUTE) { + blockEntity.setChanged(); + } + return received; + } + + @Override + public long extract(final long amount, final Action action) { + final long extracted = super.extract(amount, action); + if (extracted > 0 && action == Action.EXECUTE) { + blockEntity.setChanged(); + } + return extracted; } }