2013-03-11 18:49:01 +01:00
|
|
|
package mekanism.api;
|
|
|
|
|
|
|
|
import net.minecraft.tileentity.TileEntity;
|
|
|
|
import net.minecraftforge.common.ForgeDirection;
|
|
|
|
|
2013-04-01 01:12:10 +02:00
|
|
|
/**
|
|
|
|
* A handy class containing several utilities for efficient gas transfer.
|
|
|
|
* @author AidanBrady
|
|
|
|
*
|
|
|
|
*/
|
2013-04-18 04:40:11 +02:00
|
|
|
public final class GasTransmission
|
2013-03-11 18:49:01 +01:00
|
|
|
{
|
|
|
|
/**
|
|
|
|
* Gets all the tubes around a tile entity.
|
|
|
|
* @param tileEntity - center tile entity
|
|
|
|
* @return array of TileEntities
|
|
|
|
*/
|
|
|
|
public static TileEntity[] getConnectedTubes(TileEntity tileEntity)
|
|
|
|
{
|
|
|
|
TileEntity[] tubes = new TileEntity[] {null, null, null, null, null, null};
|
|
|
|
|
2013-03-25 17:00:45 +01:00
|
|
|
for(ForgeDirection orientation : ForgeDirection.VALID_DIRECTIONS)
|
2013-03-11 18:49:01 +01:00
|
|
|
{
|
2013-04-23 21:36:43 +02:00
|
|
|
TileEntity tube = Object3D.get(tileEntity).getFromSide(orientation).getTileEntity(tileEntity.worldObj);
|
2013-03-25 17:00:45 +01:00
|
|
|
|
2013-04-13 02:30:00 +02:00
|
|
|
if(tube instanceof IPressurizedTube && ((IPressurizedTube)tube).canTransferGas(tileEntity))
|
2013-03-25 17:00:45 +01:00
|
|
|
{
|
|
|
|
tubes[orientation.ordinal()] = tube;
|
|
|
|
}
|
2013-03-11 18:49:01 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
return tubes;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Gets all the acceptors around a tile entity.
|
|
|
|
* @param tileEntity - center tile entity
|
|
|
|
* @return array of IGasAcceptors
|
|
|
|
*/
|
|
|
|
public static IGasAcceptor[] getConnectedAcceptors(TileEntity tileEntity)
|
|
|
|
{
|
|
|
|
IGasAcceptor[] acceptors = new IGasAcceptor[] {null, null, null, null, null, null};
|
|
|
|
|
2013-03-25 17:00:45 +01:00
|
|
|
for(ForgeDirection orientation : ForgeDirection.VALID_DIRECTIONS)
|
2013-03-11 18:49:01 +01:00
|
|
|
{
|
2013-04-23 21:36:43 +02:00
|
|
|
TileEntity acceptor = Object3D.get(tileEntity).getFromSide(orientation).getTileEntity(tileEntity.worldObj);
|
2013-03-25 17:00:45 +01:00
|
|
|
|
|
|
|
if(acceptor instanceof IGasAcceptor)
|
|
|
|
{
|
|
|
|
acceptors[orientation.ordinal()] = (IGasAcceptor)acceptor;
|
|
|
|
}
|
2013-03-11 18:49:01 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
return acceptors;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Gets all the tube connections around a tile entity.
|
|
|
|
* @param tileEntity - center tile entity
|
|
|
|
* @return array of ITubeConnections
|
|
|
|
*/
|
|
|
|
public static ITubeConnection[] getConnections(TileEntity tileEntity)
|
|
|
|
{
|
|
|
|
ITubeConnection[] connections = new ITubeConnection[] {null, null, null, null, null, null};
|
|
|
|
|
2013-03-25 17:00:45 +01:00
|
|
|
for(ForgeDirection orientation : ForgeDirection.VALID_DIRECTIONS)
|
2013-03-11 18:49:01 +01:00
|
|
|
{
|
2013-04-23 21:36:43 +02:00
|
|
|
TileEntity connection = Object3D.get(tileEntity).getFromSide(orientation).getTileEntity(tileEntity.worldObj);
|
2013-03-25 17:00:45 +01:00
|
|
|
|
|
|
|
if(connection instanceof ITubeConnection)
|
|
|
|
{
|
|
|
|
connections[orientation.ordinal()] = (ITubeConnection)connection;
|
|
|
|
}
|
2013-03-11 18:49:01 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
return connections;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Emits a defined gas to the network.
|
|
|
|
* @param type - gas type to send
|
|
|
|
* @param amount - amount of gas to send
|
|
|
|
* @param sender - the sender of the gas
|
|
|
|
* @param facing - side the sender is outputting from
|
|
|
|
* @return rejected gas
|
|
|
|
*/
|
|
|
|
public static int emitGasToNetwork(EnumGas type, int amount, TileEntity sender, ForgeDirection facing)
|
|
|
|
{
|
2013-04-23 21:36:43 +02:00
|
|
|
TileEntity pointer = Object3D.get(sender).getFromSide(facing).getTileEntity(sender.worldObj);
|
2013-03-11 18:49:01 +01:00
|
|
|
|
2013-03-25 17:00:45 +01:00
|
|
|
if(pointer instanceof IPressurizedTube)
|
|
|
|
{
|
|
|
|
return new GasTransferProtocol(pointer, sender, type, amount).calculate();
|
|
|
|
}
|
|
|
|
|
|
|
|
return amount;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Emits gas from all sides of a TileEntity.
|
|
|
|
* @param type - gas type to send
|
|
|
|
* @param amount - amount of gas to send
|
|
|
|
* @param pointer - sending TileEntity
|
|
|
|
* @return rejected gas
|
|
|
|
*/
|
|
|
|
public static int emitGasFromAllSides(EnumGas type, int amount, TileEntity pointer)
|
|
|
|
{
|
2013-03-11 18:49:01 +01:00
|
|
|
if(pointer != null)
|
|
|
|
{
|
2013-03-25 17:00:45 +01:00
|
|
|
return new GasTransferProtocol(pointer, pointer, type, amount).calculate();
|
2013-03-11 18:49:01 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
return amount;
|
|
|
|
}
|
|
|
|
}
|