From a2da91732db6464ea662e815c302f37458111e47 Mon Sep 17 00:00:00 2001 From: raoulvdberge Date: Sat, 12 Oct 2024 17:07:31 +0200 Subject: [PATCH] fix: the configuration card is now stack sensitive To transfer a configured Regulator Upgrade for example. --- CHANGELOG.md | 1 + .../configurationcard/ConfigurationCardTarget.java | 5 ++--- .../common/autocrafting/AutocrafterBlockEntity.java | 4 ++-- .../common/autocrafting/PatternItemOverrides.java | 2 +- .../configurationcard/ConfigurationCardItem.java | 13 ++++++------- .../configurationcard/ConfigurationCardState.java | 13 +++++-------- .../AbstractConstructorBlockEntity.java | 4 ++-- .../AbstractDestructorBlockEntity.java | 5 ++--- .../exporter/AbstractExporterBlockEntity.java | 4 ++-- .../importer/AbstractImporterBlockEntity.java | 4 ++-- .../networking/WirelessTransmitterBlockEntity.java | 4 ++-- .../AbstractDiskInterfaceBlockEntity.java | 4 ++-- .../common/upgrade/UpgradeContainer.java | 12 ++++++------ .../constructordestructor/ConstructorTest.java | 2 +- .../constructordestructor/DestructorTest.java | 2 +- .../common/exporter/ExporterTest.java | 4 ++-- .../common/importer/ImporterTest.java | 4 ++-- .../storage/diskinterface/DiskInterfaceTest.java | 4 ++-- 18 files changed, 43 insertions(+), 48 deletions(-) diff --git a/CHANGELOG.md b/CHANGELOG.md index 1d13088e1..4c09c8552 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -41,6 +41,7 @@ to [Semantic Versioning](https://semver.org/spec/v2.0.0.html). - Fixed upgrade destinations not being shown on upgrades. - Fixed resources with changed data format or ID causing entire storage to fail to load. - Fixed crash when trying to export fluids from an External Storage on Fabric. +- The Configuration Card can now also transfer the (configured) Regulator Upgrade. ## [2.0.0-milestone.4.7] - 2024-08-11 diff --git a/refinedstorage-common-api/src/main/java/com/refinedmods/refinedstorage/common/api/configurationcard/ConfigurationCardTarget.java b/refinedstorage-common-api/src/main/java/com/refinedmods/refinedstorage/common/api/configurationcard/ConfigurationCardTarget.java index 5d246efaf..420c85641 100644 --- a/refinedstorage-common-api/src/main/java/com/refinedmods/refinedstorage/common/api/configurationcard/ConfigurationCardTarget.java +++ b/refinedstorage-common-api/src/main/java/com/refinedmods/refinedstorage/common/api/configurationcard/ConfigurationCardTarget.java @@ -5,7 +5,6 @@ import net.minecraft.core.HolderLookup; import net.minecraft.nbt.CompoundTag; -import net.minecraft.world.item.Item; import net.minecraft.world.item.ItemStack; import org.apiguardian.api.API; @@ -18,11 +17,11 @@ public interface ConfigurationCardTarget { void readConfiguration(CompoundTag tag, HolderLookup.Provider provider); - default List getUpgradeItems() { + default List getUpgrades() { return Collections.emptyList(); } - default boolean addUpgradeItem(ItemStack upgradeStack) { + default boolean addUpgrade(ItemStack upgradeStack) { return false; } } diff --git a/refinedstorage-common/src/main/java/com/refinedmods/refinedstorage/common/autocrafting/AutocrafterBlockEntity.java b/refinedstorage-common/src/main/java/com/refinedmods/refinedstorage/common/autocrafting/AutocrafterBlockEntity.java index df3cadde9..3b6401a9c 100644 --- a/refinedstorage-common/src/main/java/com/refinedmods/refinedstorage/common/autocrafting/AutocrafterBlockEntity.java +++ b/refinedstorage-common/src/main/java/com/refinedmods/refinedstorage/common/autocrafting/AutocrafterBlockEntity.java @@ -230,12 +230,12 @@ protected boolean hasRedstoneMode() { } @Override - public List getUpgradeItems() { + public List getUpgrades() { return upgradeContainer.getUpgradeItems(); } @Override - public boolean addUpgradeItem(final ItemStack upgradeStack) { + public boolean addUpgrade(final ItemStack upgradeStack) { return upgradeContainer.addUpgradeItem(upgradeStack); } diff --git a/refinedstorage-common/src/main/java/com/refinedmods/refinedstorage/common/autocrafting/PatternItemOverrides.java b/refinedstorage-common/src/main/java/com/refinedmods/refinedstorage/common/autocrafting/PatternItemOverrides.java index 3bce9bfea..c53f3ecd5 100644 --- a/refinedstorage-common/src/main/java/com/refinedmods/refinedstorage/common/autocrafting/PatternItemOverrides.java +++ b/refinedstorage-common/src/main/java/com/refinedmods/refinedstorage/common/autocrafting/PatternItemOverrides.java @@ -21,7 +21,7 @@ public class PatternItemOverrides extends ItemOverrides { private final BakedModel stonecutterModel; private final BakedModel smithingTableModel; - @SuppressWarnings({"DataFlowIssue"}) // null is allowed as long as we don't pass overrides + @SuppressWarnings({"DataFlowIssue", "deprecation"}) // null is allowed as long as we don't pass overrides public PatternItemOverrides(final ModelBaker modelBaker, final BakedModel emptyModel, final BakedModel craftingModel, diff --git a/refinedstorage-common/src/main/java/com/refinedmods/refinedstorage/common/configurationcard/ConfigurationCardItem.java b/refinedstorage-common/src/main/java/com/refinedmods/refinedstorage/common/configurationcard/ConfigurationCardItem.java index 7b78ff02f..f6cc77056 100644 --- a/refinedstorage-common/src/main/java/com/refinedmods/refinedstorage/common/configurationcard/ConfigurationCardItem.java +++ b/refinedstorage-common/src/main/java/com/refinedmods/refinedstorage/common/configurationcard/ConfigurationCardItem.java @@ -55,7 +55,7 @@ public InteractionResult useOn(final UseOnContext ctx) { stack.set(DataComponents.INSTANCE.getConfigurationCardState(), new ConfigurationCardState( blockEntity.getType(), createConfigTag(target, ctx.getLevel().registryAccess()), - target.getUpgradeItems() + target.getUpgrades() )); sendCopiedConfigurationMessage(ctx.getPlayer(), blockEntity.getType()); return InteractionResult.CONSUME; @@ -74,7 +74,7 @@ private InteractionResult applyConfiguration( return configurationCardIsConfiguredForDifferentType(player, state.blockEntityType()); } target.readConfiguration(state.config(), provider); - tryTransferUpgrades(player, target, state.upgradeItems()); + tryTransferUpgrades(player, target, state.upgrades()); targetBlockEntity.setChanged(); player.sendSystemMessage(createTranslation("item", "configuration_card.applied_configuration")); return InteractionResult.SUCCESS; @@ -82,11 +82,10 @@ private InteractionResult applyConfiguration( private void tryTransferUpgrades(final Player player, final ConfigurationCardTarget target, - final List upgradeItems) { - for (final Item upgradeItem : upgradeItems) { - final ItemStack upgradeStack = new ItemStack(upgradeItem); - final int upgradeIndexInPlayerInventory = player.getInventory().findSlotMatchingItem(upgradeStack); - if (upgradeIndexInPlayerInventory >= 0 && target.addUpgradeItem(upgradeStack)) { + final List upgradeItems) { + for (final ItemStack upgradeItem : upgradeItems) { + final int upgradeIndexInPlayerInventory = player.getInventory().findSlotMatchingItem(upgradeItem); + if (upgradeIndexInPlayerInventory >= 0 && target.addUpgrade(upgradeItem)) { player.getInventory().removeItem(upgradeIndexInPlayerInventory, 1); } } diff --git a/refinedstorage-common/src/main/java/com/refinedmods/refinedstorage/common/configurationcard/ConfigurationCardState.java b/refinedstorage-common/src/main/java/com/refinedmods/refinedstorage/common/configurationcard/ConfigurationCardState.java index 33e3bccfd..15d37b943 100644 --- a/refinedstorage-common/src/main/java/com/refinedmods/refinedstorage/common/configurationcard/ConfigurationCardState.java +++ b/refinedstorage-common/src/main/java/com/refinedmods/refinedstorage/common/configurationcard/ConfigurationCardState.java @@ -11,27 +11,24 @@ import net.minecraft.network.RegistryFriendlyByteBuf; import net.minecraft.network.codec.ByteBufCodecs; import net.minecraft.network.codec.StreamCodec; -import net.minecraft.world.item.Item; +import net.minecraft.world.item.ItemStack; import net.minecraft.world.level.block.entity.BlockEntityType; -public record ConfigurationCardState(BlockEntityType blockEntityType, - CompoundTag config, - List upgradeItems) { +public record ConfigurationCardState(BlockEntityType blockEntityType, CompoundTag config, List upgrades) { public static final Codec CODEC = RecordCodecBuilder.create(instance -> instance.group( BuiltInRegistries.BLOCK_ENTITY_TYPE.byNameCodec().fieldOf("blockEntityType") .forGetter(ConfigurationCardState::blockEntityType), CompoundTag.CODEC.fieldOf("config") .forGetter(ConfigurationCardState::config), - Codec.list(BuiltInRegistries.ITEM.byNameCodec()).fieldOf("upgradeItems") - .forGetter(ConfigurationCardState::upgradeItems) + Codec.list(ItemStack.SINGLE_ITEM_CODEC).fieldOf("upgrades") + .forGetter(ConfigurationCardState::upgrades) ).apply(instance, ConfigurationCardState::new)); public static final StreamCodec STREAM_CODEC = StreamCodec.composite( ByteBufCodecs.registry(Registries.BLOCK_ENTITY_TYPE), ConfigurationCardState::blockEntityType, ByteBufCodecs.COMPOUND_TAG, ConfigurationCardState::config, - ByteBufCodecs.collection(ArrayList::new, ByteBufCodecs.registry(Registries.ITEM)), - ConfigurationCardState::upgradeItems, + ByteBufCodecs.collection(ArrayList::new, ItemStack.STREAM_CODEC), ConfigurationCardState::upgrades, ConfigurationCardState::new ); } diff --git a/refinedstorage-common/src/main/java/com/refinedmods/refinedstorage/common/constructordestructor/AbstractConstructorBlockEntity.java b/refinedstorage-common/src/main/java/com/refinedmods/refinedstorage/common/constructordestructor/AbstractConstructorBlockEntity.java index 75c15737e..7e8add10f 100644 --- a/refinedstorage-common/src/main/java/com/refinedmods/refinedstorage/common/constructordestructor/AbstractConstructorBlockEntity.java +++ b/refinedstorage-common/src/main/java/com/refinedmods/refinedstorage/common/constructordestructor/AbstractConstructorBlockEntity.java @@ -84,12 +84,12 @@ void setFilters(final List filters) { } @Override - public List getUpgradeItems() { + public List getUpgrades() { return upgradeContainer.getUpgradeItems(); } @Override - public boolean addUpgradeItem(final ItemStack upgradeStack) { + public boolean addUpgrade(final ItemStack upgradeStack) { return upgradeContainer.addUpgradeItem(upgradeStack); } diff --git a/refinedstorage-common/src/main/java/com/refinedmods/refinedstorage/common/constructordestructor/AbstractDestructorBlockEntity.java b/refinedstorage-common/src/main/java/com/refinedmods/refinedstorage/common/constructordestructor/AbstractDestructorBlockEntity.java index d94e3709b..c1d00b756 100644 --- a/refinedstorage-common/src/main/java/com/refinedmods/refinedstorage/common/constructordestructor/AbstractDestructorBlockEntity.java +++ b/refinedstorage-common/src/main/java/com/refinedmods/refinedstorage/common/constructordestructor/AbstractDestructorBlockEntity.java @@ -35,7 +35,6 @@ import net.minecraft.world.entity.player.Inventory; import net.minecraft.world.entity.player.Player; import net.minecraft.world.inventory.AbstractContainerMenu; -import net.minecraft.world.item.Item; import net.minecraft.world.item.ItemStack; import net.minecraft.world.level.block.state.BlockState; @@ -75,12 +74,12 @@ protected AbstractDestructorBlockEntity(final BlockPos pos, final BlockState sta } @Override - public List getUpgradeItems() { + public List getUpgrades() { return upgradeContainer.getUpgradeItems(); } @Override - public boolean addUpgradeItem(final ItemStack upgradeStack) { + public boolean addUpgrade(final ItemStack upgradeStack) { return upgradeContainer.addUpgradeItem(upgradeStack); } diff --git a/refinedstorage-common/src/main/java/com/refinedmods/refinedstorage/common/exporter/AbstractExporterBlockEntity.java b/refinedstorage-common/src/main/java/com/refinedmods/refinedstorage/common/exporter/AbstractExporterBlockEntity.java index 628263c20..227a77533 100644 --- a/refinedstorage-common/src/main/java/com/refinedmods/refinedstorage/common/exporter/AbstractExporterBlockEntity.java +++ b/refinedstorage-common/src/main/java/com/refinedmods/refinedstorage/common/exporter/AbstractExporterBlockEntity.java @@ -87,12 +87,12 @@ private void schedulingModeChanged(final SchedulingMode schedulingMode) { } @Override - public List getUpgradeItems() { + public List getUpgrades() { return upgradeContainer.getUpgradeItems(); } @Override - public boolean addUpgradeItem(final ItemStack upgradeStack) { + public boolean addUpgrade(final ItemStack upgradeStack) { return upgradeContainer.addUpgradeItem(upgradeStack); } diff --git a/refinedstorage-common/src/main/java/com/refinedmods/refinedstorage/common/importer/AbstractImporterBlockEntity.java b/refinedstorage-common/src/main/java/com/refinedmods/refinedstorage/common/importer/AbstractImporterBlockEntity.java index a19995600..e10917621 100644 --- a/refinedstorage-common/src/main/java/com/refinedmods/refinedstorage/common/importer/AbstractImporterBlockEntity.java +++ b/refinedstorage-common/src/main/java/com/refinedmods/refinedstorage/common/importer/AbstractImporterBlockEntity.java @@ -81,12 +81,12 @@ protected AbstractImporterBlockEntity(final BlockPos pos, final BlockState state } @Override - public List getUpgradeItems() { + public List getUpgrades() { return upgradeContainer.getUpgradeItems(); } @Override - public boolean addUpgradeItem(final ItemStack upgradeStack) { + public boolean addUpgrade(final ItemStack upgradeStack) { return upgradeContainer.addUpgradeItem(upgradeStack); } diff --git a/refinedstorage-common/src/main/java/com/refinedmods/refinedstorage/common/networking/WirelessTransmitterBlockEntity.java b/refinedstorage-common/src/main/java/com/refinedmods/refinedstorage/common/networking/WirelessTransmitterBlockEntity.java index 199d7649f..49ace3368 100644 --- a/refinedstorage-common/src/main/java/com/refinedmods/refinedstorage/common/networking/WirelessTransmitterBlockEntity.java +++ b/refinedstorage-common/src/main/java/com/refinedmods/refinedstorage/common/networking/WirelessTransmitterBlockEntity.java @@ -74,12 +74,12 @@ public void loadAdditional(final CompoundTag tag, final HolderLookup.Provider pr } @Override - public List getUpgradeItems() { + public List getUpgrades() { return upgradeContainer.getUpgradeItems(); } @Override - public boolean addUpgradeItem(final ItemStack upgradeStack) { + public boolean addUpgrade(final ItemStack upgradeStack) { return upgradeContainer.addUpgradeItem(upgradeStack); } diff --git a/refinedstorage-common/src/main/java/com/refinedmods/refinedstorage/common/storage/diskinterface/AbstractDiskInterfaceBlockEntity.java b/refinedstorage-common/src/main/java/com/refinedmods/refinedstorage/common/storage/diskinterface/AbstractDiskInterfaceBlockEntity.java index 792f0751a..81c72b10b 100644 --- a/refinedstorage-common/src/main/java/com/refinedmods/refinedstorage/common/storage/diskinterface/AbstractDiskInterfaceBlockEntity.java +++ b/refinedstorage-common/src/main/java/com/refinedmods/refinedstorage/common/storage/diskinterface/AbstractDiskInterfaceBlockEntity.java @@ -109,12 +109,12 @@ public void writeConfiguration(final CompoundTag tag, final HolderLookup.Provide } @Override - public List getUpgradeItems() { + public List getUpgrades() { return upgradeContainer.getUpgradeItems(); } @Override - public boolean addUpgradeItem(final ItemStack upgradeStack) { + public boolean addUpgrade(final ItemStack upgradeStack) { return upgradeContainer.addUpgradeItem(upgradeStack); } diff --git a/refinedstorage-common/src/main/java/com/refinedmods/refinedstorage/common/upgrade/UpgradeContainer.java b/refinedstorage-common/src/main/java/com/refinedmods/refinedstorage/common/upgrade/UpgradeContainer.java index 671a654aa..5c71dc2e6 100644 --- a/refinedstorage-common/src/main/java/com/refinedmods/refinedstorage/common/upgrade/UpgradeContainer.java +++ b/refinedstorage-common/src/main/java/com/refinedmods/refinedstorage/common/upgrade/UpgradeContainer.java @@ -39,7 +39,7 @@ public class UpgradeContainer extends SimpleContainer implements UpgradeState { private final UpgradeContainerListener listener; private final int defaultWorkTickRate; private final ThrottledNetworkNodeTicker ticker; - + public UpgradeContainer(final UpgradeDestination destination) { this(destination, null); } @@ -145,20 +145,20 @@ public long getEnergyUsage() { return usage; } - public List getUpgradeItems() { - final List upgradeItems = new ArrayList<>(); + public List getUpgradeItems() { + final List upgradeItems = new ArrayList<>(); for (int i = 0; i < getContainerSize(); ++i) { final ItemStack itemStack = getItem(i); if (itemStack.isEmpty()) { continue; } - upgradeItems.add(itemStack.getItem()); + upgradeItems.add(itemStack.copy()); } return upgradeItems; } - public boolean addUpgradeItem(final ItemStack upgradeStack) { - return addItem(upgradeStack).isEmpty(); + public boolean addUpgradeItem(final ItemStack upgradeItem) { + return addItem(upgradeItem).isEmpty(); } public NonNullList getDrops() { diff --git a/refinedstorage-neoforge/src/test/java/com/refinedmods/refinedstorage/common/constructordestructor/ConstructorTest.java b/refinedstorage-neoforge/src/test/java/com/refinedmods/refinedstorage/common/constructordestructor/ConstructorTest.java index b51cb42c3..dc4850830 100644 --- a/refinedstorage-neoforge/src/test/java/com/refinedmods/refinedstorage/common/constructordestructor/ConstructorTest.java +++ b/refinedstorage-neoforge/src/test/java/com/refinedmods/refinedstorage/common/constructordestructor/ConstructorTest.java @@ -129,7 +129,7 @@ public static void shouldDropItemWithStackUpgrade(final GameTestHelper helper) { // Act constructor.setDropItems(true); constructor.setFilters(List.of(asResource(DIRT))); - constructor.addUpgradeItem(RSITEMS.getStackUpgrade().getDefaultInstance()); + constructor.addUpgrade(RSITEMS.getStackUpgrade().getDefaultInstance()); // Assert sequence diff --git a/refinedstorage-neoforge/src/test/java/com/refinedmods/refinedstorage/common/constructordestructor/DestructorTest.java b/refinedstorage-neoforge/src/test/java/com/refinedmods/refinedstorage/common/constructordestructor/DestructorTest.java index a1eb71777..0b7d8d6cf 100644 --- a/refinedstorage-neoforge/src/test/java/com/refinedmods/refinedstorage/common/constructordestructor/DestructorTest.java +++ b/refinedstorage-neoforge/src/test/java/com/refinedmods/refinedstorage/common/constructordestructor/DestructorTest.java @@ -139,7 +139,7 @@ public static void shouldBreakBlockWithSilkTouchUpgrade(final GameTestHelper hel // Act helper.setBlock(pos.east(), Blocks.DIAMOND_ORE); - destructor.addUpgradeItem(RSITEMS.getSilkTouchUpgrade().getDefaultInstance()); + destructor.addUpgrade(RSITEMS.getSilkTouchUpgrade().getDefaultInstance()); // Assert sequence diff --git a/refinedstorage-neoforge/src/test/java/com/refinedmods/refinedstorage/common/exporter/ExporterTest.java b/refinedstorage-neoforge/src/test/java/com/refinedmods/refinedstorage/common/exporter/ExporterTest.java index b8d3d7e7c..09e93ba91 100644 --- a/refinedstorage-neoforge/src/test/java/com/refinedmods/refinedstorage/common/exporter/ExporterTest.java +++ b/refinedstorage-neoforge/src/test/java/com/refinedmods/refinedstorage/common/exporter/ExporterTest.java @@ -80,7 +80,7 @@ public static void shouldExportItemWithStackUpgrade(final GameTestHelper helper) // Act exporter.setFilters(List.of(asResource(DIRT))); - exporter.addUpgradeItem(RSITEMS.getStackUpgrade().getDefaultInstance()); + exporter.addUpgrade(RSITEMS.getStackUpgrade().getDefaultInstance()); // Assert sequence @@ -224,7 +224,7 @@ public static void shouldExportFluidWithStackUpgrade(final GameTestHelper helper // Act exporter.setFilters(List.of(asResource(WATER))); - exporter.addUpgradeItem(RSITEMS.getStackUpgrade().getDefaultInstance()); + exporter.addUpgrade(RSITEMS.getStackUpgrade().getDefaultInstance()); // Assert sequence diff --git a/refinedstorage-neoforge/src/test/java/com/refinedmods/refinedstorage/common/importer/ImporterTest.java b/refinedstorage-neoforge/src/test/java/com/refinedmods/refinedstorage/common/importer/ImporterTest.java index a6eefe1a1..ed203c400 100644 --- a/refinedstorage-neoforge/src/test/java/com/refinedmods/refinedstorage/common/importer/ImporterTest.java +++ b/refinedstorage-neoforge/src/test/java/com/refinedmods/refinedstorage/common/importer/ImporterTest.java @@ -90,7 +90,7 @@ public static void shouldImportItemWithStackUpgrade(final GameTestHelper helper) DIRT.getDefaultInstance() ); - importer.addUpgradeItem(RSITEMS.getStackUpgrade().getDefaultInstance()); + importer.addUpgrade(RSITEMS.getStackUpgrade().getDefaultInstance()); // Assert sequence @@ -371,7 +371,7 @@ public static void shouldImportFluidWithStackUpgrade(final GameTestHelper helper new ResourceAmount(asResource(WATER), Platform.INSTANCE.getBucketAmount() * 15), new ResourceAmount(asResource(LAVA), Platform.INSTANCE.getBucketAmount()) ); - importer.addUpgradeItem(RSITEMS.getStackUpgrade().getDefaultInstance()); + importer.addUpgrade(RSITEMS.getStackUpgrade().getDefaultInstance()); // Assert sequence diff --git a/refinedstorage-neoforge/src/test/java/com/refinedmods/refinedstorage/common/storage/diskinterface/DiskInterfaceTest.java b/refinedstorage-neoforge/src/test/java/com/refinedmods/refinedstorage/common/storage/diskinterface/DiskInterfaceTest.java index 1b89c4589..2955d51d0 100644 --- a/refinedstorage-neoforge/src/test/java/com/refinedmods/refinedstorage/common/storage/diskinterface/DiskInterfaceTest.java +++ b/refinedstorage-neoforge/src/test/java/com/refinedmods/refinedstorage/common/storage/diskinterface/DiskInterfaceTest.java @@ -76,7 +76,7 @@ public static void shouldInsertItemsIntoNetworkWithStackUpgrade(final GameTestHe // Act diskInterface.setTransferMode(StorageTransferMode.INSERT_INTO_NETWORK); - diskInterface.addUpgradeItem(RSITEMS.getStackUpgrade().getDefaultInstance()); + diskInterface.addUpgrade(RSITEMS.getStackUpgrade().getDefaultInstance()); // Assert sequence @@ -217,7 +217,7 @@ public static void shouldExtractItemsFromNetworkWithStackUpgrade(final GameTestH // Act diskInterface.setTransferMode(StorageTransferMode.EXTRACT_FROM_NETWORK); - diskInterface.addUpgradeItem(RSITEMS.getStackUpgrade().getDefaultInstance()); + diskInterface.addUpgrade(RSITEMS.getStackUpgrade().getDefaultInstance()); // Assert sequence