34 lines
1.3 KiB
Java
34 lines
1.3 KiB
Java
package ic2.api.energy.tile;
|
|
|
|
import java.util.List;
|
|
|
|
import net.minecraft.tileentity.TileEntity;
|
|
|
|
/**
|
|
* Interface for grouping multi-block structures to a single energy net delegate.
|
|
*
|
|
* The energy net uses TileEntity to refer to a specific xyz+world position. If multiple of those
|
|
* positions should belong to the same functional structure, i.e. they consume or produce energy
|
|
* only once for the whole multi-block instead of once per every single block, this interface
|
|
* allows to do so.
|
|
*
|
|
* The tile entity implementing IMetaDelegate has to be added/removed to/from the energy net
|
|
* instead of every single sub-TileEntity. The energy net interaction will be handled by the
|
|
* IMetaDelegate TileEntity as well.
|
|
*
|
|
* The sub tile array TileEntity[] just provides optional connectivity (IEnergyAcceptor,
|
|
* IEnergyEmitter) and mandatory position (x, y, z, World) data.
|
|
* If the connectivity data on the sub tile is missing, the meta delegate is queried instead.
|
|
*
|
|
* See ic2/api/energy/usage.txt for an overall description of the energy net api.
|
|
*/
|
|
public interface IMetaDelegate extends IEnergyTile {
|
|
/**
|
|
* Get the sub-TileEntities belonging to this Meta TileEntity.
|
|
*
|
|
* @note the list has to be consistent between the EnergyNet Load and Unload events.
|
|
*
|
|
* @return sub-TileEntity array
|
|
*/
|
|
List<TileEntity> getSubTiles();
|
|
}
|