diff options
Diffstat (limited to 'src/main/java')
-rw-r--r-- | src/main/java/gregtech/api/objects/overclockdescriber/FusionOverclockDescriber.java | 32 |
1 files changed, 25 insertions, 7 deletions
diff --git a/src/main/java/gregtech/api/objects/overclockdescriber/FusionOverclockDescriber.java b/src/main/java/gregtech/api/objects/overclockdescriber/FusionOverclockDescriber.java index 43ce1c8760..0883aefc34 100644 --- a/src/main/java/gregtech/api/objects/overclockdescriber/FusionOverclockDescriber.java +++ b/src/main/java/gregtech/api/objects/overclockdescriber/FusionOverclockDescriber.java @@ -9,6 +9,7 @@ import gregtech.api.util.GT_OverclockCalculator; import gregtech.api.util.GT_Recipe; import gregtech.api.util.GT_Utility; import gregtech.api.util.MethodsReturnNonnullByDefault; +import gregtech.common.tileentities.machines.multi.GT_MetaTileEntity_FusionComputer; @ParametersAreNonnullByDefault @MethodsReturnNonnullByDefault @@ -16,6 +17,19 @@ public class FusionOverclockDescriber extends EUOverclockDescriber { protected final long capableStartup; + /** + * The values of {@link GT_MetaTileEntity_FusionComputer#capableStartupCanonical()} from MK1 ~ MK5 + */ + public static long getCapableStartupCanonical(int tier) { + return switch (tier) { + case 1 -> 160_000_000L; + case 2 -> 320_000_000L; + case 3 -> 640_000_000L; + case 4 -> 5_120_000_000L; + default -> 20_480_000_000L; + }; + } + public FusionOverclockDescriber(byte energyTier, long capableStartup) { super(energyTier, 1); this.capableStartup = capableStartup; @@ -50,15 +64,19 @@ public class FusionOverclockDescriber extends EUOverclockDescriber { return this.capableStartup >= recipe.mSpecialValue; } - protected int overclock(int startEnergy) { + protected int overclock(long startEnergy) { return switch (getFusionTier()) { case 1 -> 0; - case 2 -> (startEnergy <= 160000000) ? 1 : 0; - case 3 -> (startEnergy <= 160000000) ? 2 : ((startEnergy <= 320000000) ? 1 : 0); - case 4 -> (startEnergy <= 160000000) ? 3 - : (startEnergy <= 320000000) ? 2 : (startEnergy <= 640000000) ? 1 : 0; - case 5 -> (startEnergy <= 160000000) ? 4 - : (startEnergy <= 320000000) ? 3 : (startEnergy <= 640000000) ? 2 : (startEnergy <= 1280000000) ? 1 : 0; + case 2 -> (startEnergy <= getCapableStartupCanonical(1)) ? 1 : 0; + case 3 -> (startEnergy <= getCapableStartupCanonical(1)) ? 2 + : ((startEnergy <= getCapableStartupCanonical(2)) ? 1 : 0); + case 4 -> (startEnergy <= getCapableStartupCanonical(1)) ? 3 + : (startEnergy <= getCapableStartupCanonical(2)) ? 2 + : (startEnergy <= getCapableStartupCanonical(3)) ? 1 : 0; + case 5 -> (startEnergy <= getCapableStartupCanonical(1)) ? 4 + : (startEnergy <= getCapableStartupCanonical(2)) ? 3 + : (startEnergy <= getCapableStartupCanonical(3)) ? 2 + : (startEnergy <= getCapableStartupCanonical(4)) ? 1 : 0; default -> throw new IllegalStateException("Unexpected fusion tier: " + getFusionTier()); }; } |