2013-11-26 20:11:26 -05:00
|
|
|
package mekanism.api.gas;
|
|
|
|
|
|
|
|
import net.minecraft.nbt.NBTTagCompound;
|
|
|
|
|
2013-12-23 17:06:22 -05:00
|
|
|
/**
|
|
|
|
* GasStack - a specified amount of a defined Gas with certain properties.
|
|
|
|
* @author aidancbrady
|
|
|
|
*
|
|
|
|
*/
|
2013-11-26 20:11:26 -05:00
|
|
|
public class GasStack
|
|
|
|
{
|
|
|
|
private Gas type;
|
2013-12-23 17:06:22 -05:00
|
|
|
|
2013-11-26 20:11:26 -05:00
|
|
|
public int amount;
|
|
|
|
|
2013-12-23 17:06:22 -05:00
|
|
|
/**
|
|
|
|
* Creates a new GasStack with a defined gas ID and quantity.
|
|
|
|
* @param id - gas ID to associate this GasStack to, will perform a GasRegistry lookup in the constructor
|
|
|
|
* @param quantity - amount of gas to be referenced in this GasStack
|
|
|
|
*/
|
2013-11-26 20:11:26 -05:00
|
|
|
public GasStack(int id, int quantity)
|
|
|
|
{
|
|
|
|
type = GasRegistry.getGas(id);
|
|
|
|
amount = quantity;
|
|
|
|
}
|
|
|
|
|
2013-12-23 17:06:22 -05:00
|
|
|
/**
|
|
|
|
* Creates a new GasStack with a defined Gas type and quantity.
|
|
|
|
* @param gas - gas type of the stack
|
|
|
|
* @param quantity - amount of gas to be referenced in this GasStack
|
|
|
|
*/
|
2013-11-26 20:11:26 -05:00
|
|
|
public GasStack(Gas gas, int quantity)
|
|
|
|
{
|
|
|
|
type = gas;
|
|
|
|
amount = quantity;
|
|
|
|
}
|
|
|
|
|
|
|
|
private GasStack() {}
|
|
|
|
|
2013-12-23 17:06:22 -05:00
|
|
|
/**
|
|
|
|
* Gets the Gas type of this GasStack.
|
|
|
|
* @return this GasStack's Gas type
|
|
|
|
*/
|
2013-11-26 20:11:26 -05:00
|
|
|
public Gas getGas()
|
|
|
|
{
|
|
|
|
return type;
|
|
|
|
}
|
|
|
|
|
2013-12-23 17:06:22 -05:00
|
|
|
/**
|
|
|
|
* Writes this GasStack to a defined tag compound.
|
|
|
|
* @param nbtTags - tag compound to write to
|
|
|
|
* @return tag compound with this GasStack's data
|
|
|
|
*/
|
2013-11-26 20:11:26 -05:00
|
|
|
public NBTTagCompound write(NBTTagCompound nbtTags)
|
|
|
|
{
|
|
|
|
type.write(nbtTags);
|
|
|
|
nbtTags.setInteger("amount", amount);
|
|
|
|
|
|
|
|
return nbtTags;
|
|
|
|
}
|
|
|
|
|
2013-12-23 17:06:22 -05:00
|
|
|
/**
|
|
|
|
* Reads this GasStack's data from a defined tag compound.
|
|
|
|
* @param nbtTags - tag compound to read from
|
|
|
|
*/
|
2013-12-18 18:39:49 -05:00
|
|
|
public void read(NBTTagCompound nbtTags)
|
2013-11-26 20:11:26 -05:00
|
|
|
{
|
|
|
|
type = Gas.readFromNBT(nbtTags);
|
|
|
|
amount = nbtTags.getInteger("amount");
|
|
|
|
}
|
|
|
|
|
2013-12-23 17:06:22 -05:00
|
|
|
/**
|
|
|
|
* Returns the GasStack stored in the defined tag compound, or null if it doesn't exist.
|
|
|
|
* @param nbtTags - tag compound to read from
|
|
|
|
* @return GasStack stored in the tag compound
|
|
|
|
*/
|
2013-11-26 20:11:26 -05:00
|
|
|
public static GasStack readFromNBT(NBTTagCompound nbtTags)
|
|
|
|
{
|
|
|
|
if(nbtTags == null || nbtTags.hasNoTags())
|
|
|
|
{
|
|
|
|
return null;
|
|
|
|
}
|
|
|
|
|
|
|
|
GasStack stack = new GasStack();
|
|
|
|
stack.read(nbtTags);
|
|
|
|
|
2013-11-30 11:31:18 -05:00
|
|
|
if(stack.getGas() == null)
|
|
|
|
{
|
|
|
|
return null;
|
|
|
|
}
|
|
|
|
|
2013-11-26 20:11:26 -05:00
|
|
|
return stack;
|
|
|
|
}
|
|
|
|
|
2013-12-23 17:06:22 -05:00
|
|
|
/**
|
|
|
|
* Returns a copied form of this GasStack.
|
|
|
|
* @return copied GasStack
|
|
|
|
*/
|
2013-11-26 20:11:26 -05:00
|
|
|
public GasStack copy()
|
|
|
|
{
|
|
|
|
return new GasStack(type, amount);
|
|
|
|
}
|
|
|
|
|
|
|
|
@Override
|
|
|
|
public String toString()
|
|
|
|
{
|
|
|
|
return "[" + type + ", " + amount + "]";
|
|
|
|
}
|
|
|
|
}
|