42 lines
1.1 KiB
Java
42 lines
1.1 KiB
Java
|
package mekanism.api.gas;
|
||
|
|
||
|
import net.minecraftforge.common.ForgeDirection;
|
||
|
|
||
|
/**
|
||
|
* Implement this if your tile entity accepts gas from a foreign, external source.
|
||
|
* @author AidanBrady
|
||
|
*
|
||
|
*/
|
||
|
public interface IGasHandler
|
||
|
{
|
||
|
/**
|
||
|
* Transfer a certain amount of gas to this block.
|
||
|
* @param amount - amount to transfer
|
||
|
* @return gas added
|
||
|
*/
|
||
|
public int receiveGas(ForgeDirection side, GasStack stack);
|
||
|
|
||
|
/**
|
||
|
* Draws a certain amount of gas from this block.
|
||
|
* @param amount - amount to draw
|
||
|
* @return gas drawn
|
||
|
*/
|
||
|
public GasStack drawGas(ForgeDirection side, int amount);
|
||
|
|
||
|
/**
|
||
|
* Whether or not this block can accept gas from a certain side.
|
||
|
* @param side - side to check
|
||
|
* @param type - type of gas to check
|
||
|
* @return if block accepts gas
|
||
|
*/
|
||
|
public boolean canReceiveGas(ForgeDirection side, Gas type);
|
||
|
|
||
|
/**
|
||
|
* Whether or not this block can be drawn of gas from a certain side.
|
||
|
* @param side - side to check
|
||
|
* @param type - type of gas to check
|
||
|
* @return if block can be drawn of gas
|
||
|
*/
|
||
|
public boolean canDrawGas(ForgeDirection side, Gas type);
|
||
|
}
|