2013-12-12 22:54:55 +01:00
|
|
|
package mekanism.api.gas;
|
|
|
|
|
|
|
|
import net.minecraft.nbt.NBTTagCompound;
|
|
|
|
|
2013-12-23 23:06:22 +01:00
|
|
|
/**
|
|
|
|
* An optional way of managing and/or storing gasses. Would be very useful in TileEntity and Entity gas storage.
|
|
|
|
* @author aidancbrady
|
|
|
|
*
|
|
|
|
*/
|
2013-12-12 22:54:55 +01:00
|
|
|
public class GasTank
|
|
|
|
{
|
|
|
|
public GasStack stored;
|
|
|
|
|
2013-12-23 23:06:22 +01:00
|
|
|
private int maxGas;
|
2013-12-12 22:54:55 +01:00
|
|
|
|
|
|
|
private GasTank() {}
|
|
|
|
|
2013-12-23 23:06:22 +01:00
|
|
|
/**
|
|
|
|
* Creates a tank with a defined capacity.
|
|
|
|
* @param max - the maximum amount of gas this GasTank can hold
|
|
|
|
*/
|
2013-12-12 22:54:55 +01:00
|
|
|
public GasTank(int max)
|
|
|
|
{
|
|
|
|
maxGas = max;
|
|
|
|
}
|
|
|
|
|
2013-12-23 23:06:22 +01:00
|
|
|
/**
|
|
|
|
* Sets this tank's GasStack value to a new value. Will cap the amount to this GasTank's capacity.
|
|
|
|
* @param stack - value to set this tank's GasStack value to
|
|
|
|
*/
|
2013-12-12 22:54:55 +01:00
|
|
|
public void setGas(GasStack stack)
|
|
|
|
{
|
|
|
|
stored = stack;
|
2013-12-23 23:06:22 +01:00
|
|
|
|
|
|
|
if(stored != null)
|
|
|
|
{
|
|
|
|
stored.amount = Math.min(getMaxGas(), stored.amount);
|
|
|
|
}
|
2013-12-12 22:54:55 +01:00
|
|
|
}
|
|
|
|
|
2013-12-23 23:06:22 +01:00
|
|
|
/**
|
|
|
|
* Draws a specified amount of gas out of this tank.
|
|
|
|
* @param amount - amount to draw
|
|
|
|
* @param doDraw - if the gas should actually be removed from this tank
|
|
|
|
* @return gas taken from this GasTank as a GasStack value
|
|
|
|
*/
|
2013-12-13 00:33:56 +01:00
|
|
|
public GasStack draw(int amount, boolean doDraw)
|
2013-12-12 22:54:55 +01:00
|
|
|
{
|
|
|
|
if(stored == null || amount <= 0)
|
|
|
|
{
|
|
|
|
return null;
|
|
|
|
}
|
|
|
|
|
|
|
|
GasStack ret = new GasStack(getGas().getGas(), Math.min(getStored(), amount));
|
|
|
|
|
|
|
|
if(ret.amount > 0)
|
|
|
|
{
|
2013-12-13 00:33:56 +01:00
|
|
|
if(doDraw)
|
2013-12-12 22:54:55 +01:00
|
|
|
{
|
|
|
|
stored.amount -= ret.amount;
|
|
|
|
|
|
|
|
if(stored.amount <= 0)
|
|
|
|
{
|
|
|
|
stored = null;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
return ret;
|
|
|
|
}
|
|
|
|
|
|
|
|
return null;
|
|
|
|
}
|
|
|
|
|
2013-12-23 23:06:22 +01:00
|
|
|
/**
|
|
|
|
* Adds a specified amount of gas to this tank.
|
|
|
|
* @param amount - the GasStack for this tank to receive
|
|
|
|
* @param doReceive - if the gas should actually be added to this tank
|
|
|
|
* @return the amount of gas accepted by this tank
|
|
|
|
*/
|
2013-12-13 00:33:56 +01:00
|
|
|
public int receive(GasStack amount, boolean doReceive)
|
2013-12-12 22:54:55 +01:00
|
|
|
{
|
2013-12-23 23:06:22 +01:00
|
|
|
if(amount == null || (stored != null && stored.amount == getMaxGas()))
|
2013-12-12 22:54:55 +01:00
|
|
|
{
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
2013-12-23 23:06:22 +01:00
|
|
|
int toFill = Math.min(getMaxGas()-getStored(), amount.amount);
|
2013-12-12 22:54:55 +01:00
|
|
|
|
2013-12-13 00:33:56 +01:00
|
|
|
if(doReceive)
|
2013-12-12 22:54:55 +01:00
|
|
|
{
|
|
|
|
if(stored == null)
|
|
|
|
{
|
|
|
|
stored = amount;
|
|
|
|
}
|
|
|
|
else {
|
2013-12-23 23:06:22 +01:00
|
|
|
stored.amount = Math.min(getMaxGas(), getStored()+amount.amount);
|
2013-12-12 22:54:55 +01:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
return toFill;
|
|
|
|
}
|
|
|
|
|
2013-12-23 23:06:22 +01:00
|
|
|
/**
|
|
|
|
* If this GasTank can receive the specified type of gas. Will return false if this tank does not need anymore gas.
|
|
|
|
* @param gas - gas to check
|
|
|
|
* @return if this GasTank can accept the defined gas
|
|
|
|
*/
|
2013-12-12 22:54:55 +01:00
|
|
|
public boolean canReceive(Gas gas)
|
|
|
|
{
|
|
|
|
if(getNeeded() == 0 || stored != null && (gas != null && gas != stored.getGas()))
|
|
|
|
{
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
|
2013-12-23 23:06:22 +01:00
|
|
|
/**
|
|
|
|
* If this GasTank can be drawn of the specified type of gas. Will return false if this tank does not contain any gas.
|
|
|
|
* @param gas - gas to check
|
|
|
|
* @return if this GasTank can be drawn of the defined gas
|
|
|
|
*/
|
2013-12-12 22:54:55 +01:00
|
|
|
public boolean canDraw(Gas gas)
|
|
|
|
{
|
|
|
|
if(stored == null || (gas != null && gas != stored.getGas()))
|
|
|
|
{
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
|
2013-12-23 23:06:22 +01:00
|
|
|
/**
|
|
|
|
* Gets the amount of gas needed by this GasTank.
|
|
|
|
* @return
|
|
|
|
*/
|
2013-12-12 22:54:55 +01:00
|
|
|
public int getNeeded()
|
|
|
|
{
|
|
|
|
return getMaxGas()-getStored();
|
|
|
|
}
|
|
|
|
|
2013-12-23 23:06:22 +01:00
|
|
|
/**
|
|
|
|
* Gets the maximum amount of gas this tank can hold.
|
|
|
|
* @return - max gas
|
|
|
|
*/
|
2013-12-12 22:54:55 +01:00
|
|
|
public int getMaxGas()
|
|
|
|
{
|
|
|
|
return maxGas;
|
|
|
|
}
|
|
|
|
|
2013-12-23 23:06:22 +01:00
|
|
|
/**
|
|
|
|
* Gets the GasStack held by this GasTank.
|
|
|
|
* @return - GasStakc held by this tank
|
|
|
|
*/
|
2013-12-12 22:54:55 +01:00
|
|
|
public GasStack getGas()
|
|
|
|
{
|
|
|
|
return stored;
|
|
|
|
}
|
|
|
|
|
2013-12-23 23:06:22 +01:00
|
|
|
/**
|
|
|
|
* Gets the amount of gas stored by this GasTank.
|
|
|
|
* @return amount of gas stored
|
|
|
|
*/
|
2013-12-12 22:54:55 +01:00
|
|
|
public int getStored()
|
|
|
|
{
|
|
|
|
return stored != null ? stored.amount : 0;
|
|
|
|
}
|
|
|
|
|
2013-12-23 23:06:22 +01:00
|
|
|
/**
|
|
|
|
* Writes this tank to a defined tag compound.
|
|
|
|
* @param nbtTags - tag compound to write to
|
|
|
|
* @return tag compound with this tank's data
|
|
|
|
*/
|
2013-12-12 22:54:55 +01:00
|
|
|
public NBTTagCompound write(NBTTagCompound nbtTags)
|
|
|
|
{
|
|
|
|
if(stored != null)
|
|
|
|
{
|
2013-12-17 20:39:30 +01:00
|
|
|
nbtTags.setCompoundTag("stored", stored.write(new NBTTagCompound()));
|
2013-12-12 22:54:55 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
nbtTags.setInteger("maxGas", maxGas);
|
|
|
|
|
|
|
|
return nbtTags;
|
|
|
|
}
|
|
|
|
|
2013-12-23 23:06:22 +01:00
|
|
|
/**
|
|
|
|
* Reads this tank's data from a defined tag compound.
|
|
|
|
* @param nbtTags - tag compound to read from
|
|
|
|
*/
|
2013-12-19 00:39:49 +01:00
|
|
|
public void read(NBTTagCompound nbtTags)
|
2013-12-12 22:54:55 +01:00
|
|
|
{
|
|
|
|
if(nbtTags.hasKey("stored"))
|
|
|
|
{
|
2013-12-31 22:38:40 +01:00
|
|
|
stored = GasStack.readFromNBT(nbtTags.getCompoundTag("stored"));
|
2013-12-12 22:54:55 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
maxGas = nbtTags.getInteger("maxGas");
|
|
|
|
}
|
|
|
|
|
2013-12-23 23:06:22 +01:00
|
|
|
/**
|
|
|
|
* Returns the tank stored in the defined tag compound, or null if it doesn't exist.
|
|
|
|
* @param nbtTags - tag compound to read from
|
|
|
|
* @return tank stored in the tag compound
|
|
|
|
*/
|
2013-12-12 22:54:55 +01:00
|
|
|
public static GasTank readFromNBT(NBTTagCompound nbtTags)
|
|
|
|
{
|
|
|
|
if(nbtTags == null || nbtTags.hasNoTags())
|
|
|
|
{
|
|
|
|
return null;
|
|
|
|
}
|
|
|
|
|
|
|
|
GasTank tank = new GasTank();
|
|
|
|
tank.read(nbtTags);
|
|
|
|
|
|
|
|
return tank;
|
|
|
|
}
|
|
|
|
}
|