Bugfix: Small boiler ash types mixing (#1303)
* Bugfix: Small boiler ash types mixing Issue: Small boilers that had ash in the byproduct slot would not produce more byproduct if the fuel type was changed to one that produced a different type of ash e.g. burn a couple of coal until there is one DarkAsh in the byproduct slot, then charcoal will produce no Ash in that stack Fix: When mixing ash types, convert all the ash to less valuable light ashes - prevents any exploits for creating more dark ashes. Issue: Boilers did not stop burning fuel when full of ash Fix: added explicit check so that boilers can't burn fuel when output is stuffed (this may be a balance change, so can be removed if undesirable) Small refactoring of fuel logic so that ash conversion logic does not need to be repeated Started with small bronze boiler, will extend fix to small steel boiler if general structure approved Addresses issue #1302 * Fixed imports and typo * Extended change to small steel boiler as well
This commit is contained in:
parent
7f08c17bfc
commit
e63b03584e
2 changed files with 108 additions and 44 deletions
|
@ -10,10 +10,12 @@ import gregtech.api.metatileentity.MetaTileEntity;
|
||||||
import gregtech.api.objects.GT_RenderedTexture;
|
import gregtech.api.objects.GT_RenderedTexture;
|
||||||
import gregtech.api.util.GT_ModHandler;
|
import gregtech.api.util.GT_ModHandler;
|
||||||
import gregtech.api.util.GT_OreDictUnificator;
|
import gregtech.api.util.GT_OreDictUnificator;
|
||||||
|
import gregtech.api.util.GT_Utility;
|
||||||
import gregtech.common.GT_Pollution;
|
import gregtech.common.GT_Pollution;
|
||||||
import gregtech.common.gui.GT_Container_Boiler;
|
import gregtech.common.gui.GT_Container_Boiler;
|
||||||
import gregtech.common.gui.GT_GUIContainer_Boiler;
|
import gregtech.common.gui.GT_GUIContainer_Boiler;
|
||||||
import net.minecraft.entity.player.InventoryPlayer;
|
import net.minecraft.entity.player.InventoryPlayer;
|
||||||
|
import net.minecraft.item.ItemStack;
|
||||||
import net.minecraftforge.common.util.ForgeDirection;
|
import net.minecraftforge.common.util.ForgeDirection;
|
||||||
import net.minecraftforge.fluids.FluidStack;
|
import net.minecraftforge.fluids.FluidStack;
|
||||||
import net.minecraftforge.fluids.IFluidHandler;
|
import net.minecraftforge.fluids.IFluidHandler;
|
||||||
|
@ -114,31 +116,61 @@ public class GT_MetaTileEntity_Boiler_Bronze
|
||||||
sendSound((byte) 1);
|
sendSound((byte) 1);
|
||||||
this.mSteam.amount = 12000;
|
this.mSteam.amount = 12000;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
//Check the boiler has not been choked by output and can keep burning fuel
|
||||||
|
boolean byproductStuffed = false;
|
||||||
|
|
||||||
|
ItemStack byproductStack = aBaseMetaTileEntity.getStackInSlot(3);
|
||||||
|
|
||||||
|
if(byproductStack != null && !(GT_Utility.isStackInvalid(byproductStack)) && byproductStack.stackSize == byproductStack.getMaxStackSize()) {
|
||||||
|
byproductStuffed = true;
|
||||||
|
}
|
||||||
|
|
||||||
if ((this.mProcessingEnergy <= 0) && (aBaseMetaTileEntity.isAllowedToWork()) &&
|
if ((this.mProcessingEnergy <= 0) && (aBaseMetaTileEntity.isAllowedToWork()) &&
|
||||||
(this.mInventory[2] != null)) {
|
(this.mInventory[2] != null) && !byproductStuffed) {
|
||||||
if ((GT_OreDictUnificator.isItemStackInstanceOf(this.mInventory[2], OrePrefixes.gem.get(Materials.Coal))) || (GT_OreDictUnificator.isItemStackInstanceOf(this.mInventory[2], OrePrefixes.dust.get(Materials.Coal))) || (GT_OreDictUnificator.isItemStackInstanceOf(this.mInventory[2], OrePrefixes.dustImpure.get(Materials.Coal))) || (GT_OreDictUnificator.isItemStackInstanceOf(this.mInventory[2], OrePrefixes.crushed.get(Materials.Coal)))) {
|
int fuelEnergy = 0, byproductChance = 1;
|
||||||
this.mProcessingEnergy += 160;
|
Object byproduct = Materials.Ash;
|
||||||
aBaseMetaTileEntity.decrStackSize(2, 1);
|
boolean validFuel = false;
|
||||||
if (aBaseMetaTileEntity.getRandomNumber(3) == 0) {
|
if ((GT_OreDictUnificator.isItemStackInstanceOf(this.mInventory[2], OrePrefixes.gem.get(Materials.Coal))) ||
|
||||||
aBaseMetaTileEntity.addStackToSlot(3, GT_OreDictUnificator.get(OrePrefixes.dustTiny, Materials.DarkAsh, 1L));
|
(GT_OreDictUnificator.isItemStackInstanceOf(this.mInventory[2], OrePrefixes.dust.get(Materials.Coal))) ||
|
||||||
}
|
(GT_OreDictUnificator.isItemStackInstanceOf(this.mInventory[2], OrePrefixes.dustImpure.get(Materials.Coal))) ||
|
||||||
} else if ((GT_OreDictUnificator.isItemStackInstanceOf(this.mInventory[2], OrePrefixes.gem.get(Materials.Charcoal))) || (GT_OreDictUnificator.isItemStackInstanceOf(this.mInventory[2], OrePrefixes.dust.get(Materials.Charcoal))) || (GT_OreDictUnificator.isItemStackInstanceOf(this.mInventory[2], OrePrefixes.dustImpure.get(Materials.Charcoal))) || (GT_OreDictUnificator.isItemStackInstanceOf(this.mInventory[2], OrePrefixes.crushed.get(Materials.Charcoal)))) {
|
(GT_OreDictUnificator.isItemStackInstanceOf(this.mInventory[2], OrePrefixes.crushed.get(Materials.Coal)))) {
|
||||||
this.mProcessingEnergy += 160;
|
fuelEnergy = 160;
|
||||||
aBaseMetaTileEntity.decrStackSize(2, 1);
|
byproductChance = 3;
|
||||||
if (aBaseMetaTileEntity.getRandomNumber(3) == 0) {
|
byproduct = Materials.DarkAsh;
|
||||||
aBaseMetaTileEntity.addStackToSlot(3, GT_OreDictUnificator.get(OrePrefixes.dustTiny, Materials.Ash, 1L));
|
validFuel = true;
|
||||||
}
|
} else if ((GT_OreDictUnificator.isItemStackInstanceOf(this.mInventory[2], OrePrefixes.gem.get(Materials.Charcoal))) ||
|
||||||
|
(GT_OreDictUnificator.isItemStackInstanceOf(this.mInventory[2], OrePrefixes.dust.get(Materials.Charcoal))) ||
|
||||||
|
(GT_OreDictUnificator.isItemStackInstanceOf(this.mInventory[2], OrePrefixes.dustImpure.get(Materials.Charcoal))) ||
|
||||||
|
(GT_OreDictUnificator.isItemStackInstanceOf(this.mInventory[2], OrePrefixes.crushed.get(Materials.Charcoal)))) {
|
||||||
|
fuelEnergy = 160;
|
||||||
|
byproductChance = 3;
|
||||||
|
byproduct = Materials.Ash;
|
||||||
|
validFuel = true;
|
||||||
} else if (GT_OreDictUnificator.isItemStackInstanceOf(this.mInventory[2], "fuelCoke")) {
|
} else if (GT_OreDictUnificator.isItemStackInstanceOf(this.mInventory[2], "fuelCoke")) {
|
||||||
this.mProcessingEnergy += 640;
|
fuelEnergy = 640;
|
||||||
aBaseMetaTileEntity.decrStackSize(2, 1);
|
byproductChance = 2;
|
||||||
if (aBaseMetaTileEntity.getRandomNumber(2) == 0) {
|
byproduct = Materials.Ash;
|
||||||
aBaseMetaTileEntity.addStackToSlot(3, GT_OreDictUnificator.get(OrePrefixes.dustTiny, Materials.Ash, 1L));
|
validFuel = true;
|
||||||
|
} else if ((GT_OreDictUnificator.isItemStackInstanceOf(this.mInventory[2], OrePrefixes.gem.get(Materials.Lignite))) ||
|
||||||
|
(GT_OreDictUnificator.isItemStackInstanceOf(this.mInventory[2], OrePrefixes.dust.get(Materials.Lignite))) ||
|
||||||
|
(GT_OreDictUnificator.isItemStackInstanceOf(this.mInventory[2], OrePrefixes.dustImpure.get(Materials.Lignite))) ||
|
||||||
|
(GT_OreDictUnificator.isItemStackInstanceOf(this.mInventory[2], OrePrefixes.crushed.get(Materials.Lignite)))) {
|
||||||
|
fuelEnergy = 120;
|
||||||
|
byproductChance = 8;
|
||||||
|
byproduct = Materials.DarkAsh;
|
||||||
|
validFuel = true;
|
||||||
}
|
}
|
||||||
} else if ((GT_OreDictUnificator.isItemStackInstanceOf(this.mInventory[2], OrePrefixes.gem.get(Materials.Lignite))) || (GT_OreDictUnificator.isItemStackInstanceOf(this.mInventory[2], OrePrefixes.dust.get(Materials.Lignite))) || (GT_OreDictUnificator.isItemStackInstanceOf(this.mInventory[2], OrePrefixes.dustImpure.get(Materials.Lignite))) || (GT_OreDictUnificator.isItemStackInstanceOf(this.mInventory[2], OrePrefixes.crushed.get(Materials.Lignite)))) {
|
|
||||||
this.mProcessingEnergy += 120;
|
if(validFuel) {
|
||||||
|
this.mProcessingEnergy += fuelEnergy;
|
||||||
aBaseMetaTileEntity.decrStackSize(2, 1);
|
aBaseMetaTileEntity.decrStackSize(2, 1);
|
||||||
if (aBaseMetaTileEntity.getRandomNumber(8) == 0) {
|
if (aBaseMetaTileEntity.getRandomNumber(byproductChance) == 0) {
|
||||||
aBaseMetaTileEntity.addStackToSlot(3, GT_OreDictUnificator.get(OrePrefixes.dustTiny, Materials.DarkAsh, 1L));
|
if(!aBaseMetaTileEntity.addStackToSlot(3, GT_OreDictUnificator.get(OrePrefixes.dustTiny, byproduct, 1L))) {
|
||||||
|
//We can only get here if the output wasn't stuffed, so if the add fails, it can only be because the byproduct types don't match
|
||||||
|
//Have attempted to mix ash types, so add one to the size of the stack and convert all ash to light ashes
|
||||||
|
aBaseMetaTileEntity.setInventorySlotContents(3, GT_OreDictUnificator.get(OrePrefixes.dustTiny, Materials.Ash, byproductStack.stackSize + 1));
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -10,10 +10,12 @@ import gregtech.api.metatileentity.MetaTileEntity;
|
||||||
import gregtech.api.objects.GT_RenderedTexture;
|
import gregtech.api.objects.GT_RenderedTexture;
|
||||||
import gregtech.api.util.GT_ModHandler;
|
import gregtech.api.util.GT_ModHandler;
|
||||||
import gregtech.api.util.GT_OreDictUnificator;
|
import gregtech.api.util.GT_OreDictUnificator;
|
||||||
|
import gregtech.api.util.GT_Utility;
|
||||||
import gregtech.common.GT_Pollution;
|
import gregtech.common.GT_Pollution;
|
||||||
import gregtech.common.gui.GT_Container_Boiler;
|
import gregtech.common.gui.GT_Container_Boiler;
|
||||||
import gregtech.common.gui.GT_GUIContainer_Boiler;
|
import gregtech.common.gui.GT_GUIContainer_Boiler;
|
||||||
import net.minecraft.entity.player.InventoryPlayer;
|
import net.minecraft.entity.player.InventoryPlayer;
|
||||||
|
import net.minecraft.item.ItemStack;
|
||||||
import net.minecraftforge.common.util.ForgeDirection;
|
import net.minecraftforge.common.util.ForgeDirection;
|
||||||
import net.minecraftforge.fluids.FluidStack;
|
import net.minecraftforge.fluids.FluidStack;
|
||||||
import net.minecraftforge.fluids.IFluidHandler;
|
import net.minecraftforge.fluids.IFluidHandler;
|
||||||
|
@ -119,31 +121,61 @@ public class GT_MetaTileEntity_Boiler_Steel
|
||||||
sendSound((byte) 1);
|
sendSound((byte) 1);
|
||||||
this.mSteam.amount = 24000;
|
this.mSteam.amount = 24000;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
//Check the boiler has not been choked by output and can keep burning fuel
|
||||||
|
boolean byproductStuffed = false;
|
||||||
|
|
||||||
|
ItemStack byproductStack = aBaseMetaTileEntity.getStackInSlot(3);
|
||||||
|
|
||||||
|
if(byproductStack != null && !(GT_Utility.isStackInvalid(byproductStack)) && byproductStack.stackSize == byproductStack.getMaxStackSize()) {
|
||||||
|
byproductStuffed = true;
|
||||||
|
}
|
||||||
|
|
||||||
if ((this.mProcessingEnergy <= 0) && (aBaseMetaTileEntity.isAllowedToWork()) &&
|
if ((this.mProcessingEnergy <= 0) && (aBaseMetaTileEntity.isAllowedToWork()) &&
|
||||||
(this.mInventory[2] != null)) {
|
(this.mInventory[2] != null) && !byproductStuffed) {
|
||||||
if ((GT_OreDictUnificator.isItemStackInstanceOf(this.mInventory[2], OrePrefixes.gem.get(Materials.Coal))) || (GT_OreDictUnificator.isItemStackInstanceOf(this.mInventory[2], OrePrefixes.dust.get(Materials.Coal))) || (GT_OreDictUnificator.isItemStackInstanceOf(this.mInventory[2], OrePrefixes.dustImpure.get(Materials.Coal))) || (GT_OreDictUnificator.isItemStackInstanceOf(this.mInventory[2], OrePrefixes.crushed.get(Materials.Coal)))) {
|
int fuelEnergy = 0, byproductChance = 1;
|
||||||
this.mProcessingEnergy += 160;
|
Object byproduct = Materials.Ash;
|
||||||
aBaseMetaTileEntity.decrStackSize(2, 1);
|
boolean validFuel = false;
|
||||||
if (aBaseMetaTileEntity.getRandomNumber(3) == 0) {
|
if ((GT_OreDictUnificator.isItemStackInstanceOf(this.mInventory[2], OrePrefixes.gem.get(Materials.Coal))) ||
|
||||||
aBaseMetaTileEntity.addStackToSlot(3, GT_OreDictUnificator.get(OrePrefixes.dustTiny, Materials.DarkAsh, 1L));
|
(GT_OreDictUnificator.isItemStackInstanceOf(this.mInventory[2], OrePrefixes.dust.get(Materials.Coal))) ||
|
||||||
}
|
(GT_OreDictUnificator.isItemStackInstanceOf(this.mInventory[2], OrePrefixes.dustImpure.get(Materials.Coal))) ||
|
||||||
} else if ((GT_OreDictUnificator.isItemStackInstanceOf(this.mInventory[2], OrePrefixes.gem.get(Materials.Charcoal))) || (GT_OreDictUnificator.isItemStackInstanceOf(this.mInventory[2], OrePrefixes.dust.get(Materials.Charcoal))) || (GT_OreDictUnificator.isItemStackInstanceOf(this.mInventory[2], OrePrefixes.dustImpure.get(Materials.Charcoal))) || (GT_OreDictUnificator.isItemStackInstanceOf(this.mInventory[2], OrePrefixes.crushed.get(Materials.Charcoal)))) {
|
(GT_OreDictUnificator.isItemStackInstanceOf(this.mInventory[2], OrePrefixes.crushed.get(Materials.Coal)))) {
|
||||||
this.mProcessingEnergy += 160;
|
fuelEnergy = 160;
|
||||||
aBaseMetaTileEntity.decrStackSize(2, 1);
|
byproductChance = 3;
|
||||||
if (aBaseMetaTileEntity.getRandomNumber(3) == 0) {
|
byproduct = Materials.DarkAsh;
|
||||||
aBaseMetaTileEntity.addStackToSlot(3, GT_OreDictUnificator.get(OrePrefixes.dustTiny, Materials.Ash, 1L));
|
validFuel = true;
|
||||||
}
|
} else if ((GT_OreDictUnificator.isItemStackInstanceOf(this.mInventory[2], OrePrefixes.gem.get(Materials.Charcoal))) ||
|
||||||
|
(GT_OreDictUnificator.isItemStackInstanceOf(this.mInventory[2], OrePrefixes.dust.get(Materials.Charcoal))) ||
|
||||||
|
(GT_OreDictUnificator.isItemStackInstanceOf(this.mInventory[2], OrePrefixes.dustImpure.get(Materials.Charcoal))) ||
|
||||||
|
(GT_OreDictUnificator.isItemStackInstanceOf(this.mInventory[2], OrePrefixes.crushed.get(Materials.Charcoal)))) {
|
||||||
|
fuelEnergy = 160;
|
||||||
|
byproductChance = 3;
|
||||||
|
byproduct = Materials.Ash;
|
||||||
|
validFuel = true;
|
||||||
} else if (GT_OreDictUnificator.isItemStackInstanceOf(this.mInventory[2], "fuelCoke")) {
|
} else if (GT_OreDictUnificator.isItemStackInstanceOf(this.mInventory[2], "fuelCoke")) {
|
||||||
this.mProcessingEnergy += 640;
|
fuelEnergy = 640;
|
||||||
aBaseMetaTileEntity.decrStackSize(2, 1);
|
byproductChance = 2;
|
||||||
if (aBaseMetaTileEntity.getRandomNumber(2) == 0) {
|
byproduct = Materials.Ash;
|
||||||
aBaseMetaTileEntity.addStackToSlot(3, GT_OreDictUnificator.get(OrePrefixes.dustTiny, Materials.Ash, 1L));
|
validFuel = true;
|
||||||
|
} else if ((GT_OreDictUnificator.isItemStackInstanceOf(this.mInventory[2], OrePrefixes.gem.get(Materials.Lignite))) ||
|
||||||
|
(GT_OreDictUnificator.isItemStackInstanceOf(this.mInventory[2], OrePrefixes.dust.get(Materials.Lignite))) ||
|
||||||
|
(GT_OreDictUnificator.isItemStackInstanceOf(this.mInventory[2], OrePrefixes.dustImpure.get(Materials.Lignite))) ||
|
||||||
|
(GT_OreDictUnificator.isItemStackInstanceOf(this.mInventory[2], OrePrefixes.crushed.get(Materials.Lignite)))) {
|
||||||
|
fuelEnergy = 120;
|
||||||
|
byproductChance = 8;
|
||||||
|
byproduct = Materials.DarkAsh;
|
||||||
|
validFuel = true;
|
||||||
}
|
}
|
||||||
} else if ((GT_OreDictUnificator.isItemStackInstanceOf(this.mInventory[2], OrePrefixes.gem.get(Materials.Lignite))) || (GT_OreDictUnificator.isItemStackInstanceOf(this.mInventory[2], OrePrefixes.dust.get(Materials.Lignite))) || (GT_OreDictUnificator.isItemStackInstanceOf(this.mInventory[2], OrePrefixes.dustImpure.get(Materials.Lignite))) || (GT_OreDictUnificator.isItemStackInstanceOf(this.mInventory[2], OrePrefixes.crushed.get(Materials.Lignite)))) {
|
|
||||||
this.mProcessingEnergy += 120;
|
if(validFuel) {
|
||||||
|
this.mProcessingEnergy += fuelEnergy;
|
||||||
aBaseMetaTileEntity.decrStackSize(2, 1);
|
aBaseMetaTileEntity.decrStackSize(2, 1);
|
||||||
if (aBaseMetaTileEntity.getRandomNumber(8) == 0) {
|
if (aBaseMetaTileEntity.getRandomNumber(byproductChance) == 0) {
|
||||||
aBaseMetaTileEntity.addStackToSlot(3, GT_OreDictUnificator.get(OrePrefixes.dustTiny, Materials.DarkAsh, 1L));
|
if(!aBaseMetaTileEntity.addStackToSlot(3, GT_OreDictUnificator.get(OrePrefixes.dustTiny, byproduct, 1L))) {
|
||||||
|
//We can only get here if the output wasn't stuffed, so if the add fails, it can only be because the byproduct types don't match
|
||||||
|
//Have attempted to mix ash types, so add one to the size of the stack and convert all ash to light ashes
|
||||||
|
aBaseMetaTileEntity.setInventorySlotContents(3, GT_OreDictUnificator.get(OrePrefixes.dustTiny, Materials.Ash, byproductStack.stackSize + 1));
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue