2013-11-14 21:58:32 -05:00
|
|
|
package cofh.api.energy;
|
|
|
|
|
|
|
|
import net.minecraftforge.common.ForgeDirection;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Implement this interface on TileEntities which should handle energy, generally storing it in one or more internal {@link IEnergyStorage} objects.
|
|
|
|
*
|
|
|
|
* A reference implementation is provided {@link TileEnergyHandler}.
|
|
|
|
*
|
|
|
|
* @author King Lemming
|
|
|
|
*
|
|
|
|
*/
|
|
|
|
public interface IEnergyHandler {
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Add energy to an IEnergyHandler, internal distribution is left entirely to the IEnergyHandler.
|
|
|
|
*
|
|
|
|
* @param from
|
|
|
|
* Orientation the energy is received from.
|
|
|
|
* @param maxReceive
|
2014-01-03 14:26:41 -05:00
|
|
|
* Maximum amount of energy to receive.
|
2013-11-14 21:58:32 -05:00
|
|
|
* @param simulate
|
|
|
|
* If TRUE, the charge will only be simulated.
|
|
|
|
* @return Amount of energy that was (or would have been, if simulated) received.
|
|
|
|
*/
|
|
|
|
int receiveEnergy(ForgeDirection from, int maxReceive, boolean simulate);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Remove energy from an IEnergyHandler, internal distribution is left entirely to the IEnergyHandler.
|
|
|
|
*
|
|
|
|
* @param from
|
2014-01-03 14:26:41 -05:00
|
|
|
* Orientation the energy is extracted from.
|
2013-11-14 21:58:32 -05:00
|
|
|
* @param maxExtract
|
|
|
|
* Maximum amount of energy to extract.
|
|
|
|
* @param simulate
|
2014-01-03 14:26:41 -05:00
|
|
|
* If TRUE, the extraction will only be simulated.
|
2013-11-14 21:58:32 -05:00
|
|
|
* @return Amount of energy that was (or would have been, if simulated) extracted.
|
|
|
|
*/
|
|
|
|
int extractEnergy(ForgeDirection from, int maxExtract, boolean simulate);
|
|
|
|
|
|
|
|
/**
|
2014-01-03 14:26:41 -05:00
|
|
|
* Returns true if the Handler functions on a given side - if a Tile Entity can receive or send energy on a given side, this should return true.
|
2013-11-14 21:58:32 -05:00
|
|
|
*/
|
|
|
|
boolean canInterface(ForgeDirection from);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Returns the amount of energy currently stored.
|
|
|
|
*/
|
|
|
|
int getEnergyStored(ForgeDirection from);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Returns the maximum amount of energy that can be stored.
|
|
|
|
*/
|
|
|
|
int getMaxEnergyStored(ForgeDirection from);
|
|
|
|
|
|
|
|
}
|