diff --git a/src/main/java/com/gregtechceu/gtceu/api/machine/MachineDefinition.java b/src/main/java/com/gregtechceu/gtceu/api/machine/MachineDefinition.java index 7a2eb0d22a..243c3eecfe 100644 --- a/src/main/java/com/gregtechceu/gtceu/api/machine/MachineDefinition.java +++ b/src/main/java/com/gregtechceu/gtceu/api/machine/MachineDefinition.java @@ -89,6 +89,9 @@ public class MachineDefinition implements Supplier { @Getter @Setter private Consumer afterWorking = (machine) -> {}; + @Getter + @Setter + private boolean regressWhenWaiting = true; @Getter @Setter diff --git a/src/main/java/com/gregtechceu/gtceu/api/machine/feature/IRecipeLogicMachine.java b/src/main/java/com/gregtechceu/gtceu/api/machine/feature/IRecipeLogicMachine.java index d82865c0a0..e3b85abe06 100644 --- a/src/main/java/com/gregtechceu/gtceu/api/machine/feature/IRecipeLogicMachine.java +++ b/src/main/java/com/gregtechceu/gtceu/api/machine/feature/IRecipeLogicMachine.java @@ -108,7 +108,7 @@ default void afterWorking() { * Whether progress decrease when machine is waiting for pertick ingredients. (e.g. lack of EU) */ default boolean dampingWhenWaiting() { - return true; + return self().getDefinition().isRegressWhenWaiting(); } /** diff --git a/src/main/java/com/gregtechceu/gtceu/api/registry/registrate/MachineBuilder.java b/src/main/java/com/gregtechceu/gtceu/api/registry/registrate/MachineBuilder.java index 87d8e01355..648eaa67b6 100644 --- a/src/main/java/com/gregtechceu/gtceu/api/registry/registrate/MachineBuilder.java +++ b/src/main/java/com/gregtechceu/gtceu/api/registry/registrate/MachineBuilder.java @@ -146,6 +146,9 @@ public class MachineBuilder extends Builde @Getter @Setter private Consumer afterWorking = (machine) -> {}; + @Getter + @Setter + private boolean regressWhenWaiting = true; @Setter private Supplier appearance; @@ -365,6 +368,7 @@ public DEFINITION register() { definition.setOnWorking(this.onWorking); definition.setOnWaiting(this.onWaiting); definition.setAfterWorking(this.afterWorking); + definition.setRegressWhenWaiting(this.regressWhenWaiting); if (renderer == null) { renderer = () -> new MachineRenderer(new ResourceLocation(registrate.getModid(), "block/machine/" + name)); diff --git a/src/main/java/com/gregtechceu/gtceu/api/registry/registrate/MultiblockMachineBuilder.java b/src/main/java/com/gregtechceu/gtceu/api/registry/registrate/MultiblockMachineBuilder.java index 2da6530b57..85216242c7 100644 --- a/src/main/java/com/gregtechceu/gtceu/api/registry/registrate/MultiblockMachineBuilder.java +++ b/src/main/java/com/gregtechceu/gtceu/api/registry/registrate/MultiblockMachineBuilder.java @@ -368,6 +368,11 @@ public MultiblockMachineBuilder afterWorking(Consumer after return (MultiblockMachineBuilder) super.afterWorking(afterWorking); } + @Override + public MultiblockMachineBuilder regressWhenWaiting(boolean dampingWhenWaiting) { + return (MultiblockMachineBuilder) super.regressWhenWaiting(dampingWhenWaiting); + } + @Override public MultiblockMachineBuilder editableUI(@Nullable EditableMachineUI editableUI) { return (MultiblockMachineBuilder) super.editableUI(editableUI);