From 3ecd03bdaa2ee28da6e50fd7436afe57cf79b462 Mon Sep 17 00:00:00 2001 From: Sebastian Hartte Date: Tue, 12 Mar 2024 02:28:49 +0100 Subject: [PATCH] Pattern providers now only push ingredients for crafting patterns to molecular assemblers, not other inventories --- src/main/java/appeng/api/crafting/IPatternDetails.java | 10 ++++++++++ .../crafting/IMolecularAssemblerSupportedPattern.java | 6 ++++++ .../helpers/patternprovider/PatternProviderLogic.java | 6 ++++++ 3 files changed, 22 insertions(+) diff --git a/src/main/java/appeng/api/crafting/IPatternDetails.java b/src/main/java/appeng/api/crafting/IPatternDetails.java index 40388c067ba..627647ee51a 100644 --- a/src/main/java/appeng/api/crafting/IPatternDetails.java +++ b/src/main/java/appeng/api/crafting/IPatternDetails.java @@ -65,6 +65,16 @@ default GenericStack getPrimaryOutput() { */ GenericStack[] getOutputs(); + /** + * @return True if this pattern allows its inputs to be pushed to generic external inventories that would accept + * those inputs. This would usually be true for custom processing patterns, but not true for patterns that + * require custom machines or molecular assemblers (since those are pushed via + * {@link ICraftingMachine#pushPattern}). + */ + default boolean supportsPushInputsToExternalInventory() { + return true; + } + /** * Gives the pattern a chance to reorder its inputs for pushing to external inventories (i.e. NOT to * {@link ICraftingMachine}s). diff --git a/src/main/java/appeng/blockentity/crafting/IMolecularAssemblerSupportedPattern.java b/src/main/java/appeng/blockentity/crafting/IMolecularAssemblerSupportedPattern.java index f22dee82aee..ec84d757a7d 100644 --- a/src/main/java/appeng/blockentity/crafting/IMolecularAssemblerSupportedPattern.java +++ b/src/main/java/appeng/blockentity/crafting/IMolecularAssemblerSupportedPattern.java @@ -22,6 +22,12 @@ public interface IMolecularAssemblerSupportedPattern extends IPatternDetails { void fillCraftingGrid(KeyCounter[] table, CraftingGridAccessor gridAccessor); + @Override + default boolean supportsPushInputsToExternalInventory() { + // Patterns crafted in a molecular assembler are usually pointless to craft in anything else + return false; + } + @FunctionalInterface interface CraftingGridAccessor { void set(int slot, ItemStack stack); diff --git a/src/main/java/appeng/helpers/patternprovider/PatternProviderLogic.java b/src/main/java/appeng/helpers/patternprovider/PatternProviderLogic.java index 44f7d3f02cd..bf4c69b318e 100644 --- a/src/main/java/appeng/helpers/patternprovider/PatternProviderLogic.java +++ b/src/main/java/appeng/helpers/patternprovider/PatternProviderLogic.java @@ -330,6 +330,12 @@ record PushTarget(Direction direction, PatternProviderTarget target) { possibleTargets.add(new PushTarget(direction, adapter)); } + // If no dedicated crafting machine could be found, and the pattern does not support + // generic external inventories, stop here. + if (!patternDetails.supportsPushInputsToExternalInventory()) { + return false; + } + // Rearrange for round-robin rearrangeRoundRobin(possibleTargets);