2015-08-29 14:33:25 +02:00
|
|
|
/*
|
2016-05-16 22:52:27 +02:00
|
|
|
* This file ("TileEntityBase.java") is part of the Actually Additions mod for Minecraft.
|
2015-08-29 14:33:25 +02:00
|
|
|
* It is created and owned by Ellpeck and distributed
|
|
|
|
* under the Actually Additions License to be found at
|
2016-05-16 22:52:27 +02:00
|
|
|
* http://ellpeck.de/actaddlicense
|
2015-08-29 14:33:25 +02:00
|
|
|
* View the source code at https://github.com/Ellpeck/ActuallyAdditions
|
|
|
|
*
|
2017-01-01 16:23:26 +01:00
|
|
|
* © 2015-2017 Ellpeck
|
2015-08-29 14:33:25 +02:00
|
|
|
*/
|
|
|
|
|
2016-01-05 04:47:35 +01:00
|
|
|
package de.ellpeck.actuallyadditions.mod.tile;
|
2014-12-12 15:40:01 +01:00
|
|
|
|
2016-01-05 04:47:35 +01:00
|
|
|
import de.ellpeck.actuallyadditions.mod.config.values.ConfigIntValues;
|
2016-01-17 20:46:51 +01:00
|
|
|
import de.ellpeck.actuallyadditions.mod.network.PacketHandler;
|
2016-06-15 16:43:59 +02:00
|
|
|
import de.ellpeck.actuallyadditions.mod.network.PacketServerToClient;
|
2016-01-05 04:47:35 +01:00
|
|
|
import de.ellpeck.actuallyadditions.mod.util.ModUtil;
|
2016-06-17 13:25:15 +02:00
|
|
|
import de.ellpeck.actuallyadditions.mod.util.WorldUtil;
|
2016-01-07 23:42:42 +01:00
|
|
|
import net.minecraft.block.state.IBlockState;
|
2016-05-06 23:23:29 +02:00
|
|
|
import net.minecraft.entity.player.EntityPlayer;
|
2015-06-15 22:06:07 +02:00
|
|
|
import net.minecraft.nbt.NBTTagCompound;
|
|
|
|
import net.minecraft.network.NetworkManager;
|
2016-03-18 23:47:22 +01:00
|
|
|
import net.minecraft.network.play.server.SPacketUpdateTileEntity;
|
2014-12-12 15:40:01 +01:00
|
|
|
import net.minecraft.tileentity.TileEntity;
|
2016-06-05 02:16:52 +02:00
|
|
|
import net.minecraft.util.EnumFacing;
|
2016-01-07 23:42:42 +01:00
|
|
|
import net.minecraft.util.ITickable;
|
2016-03-18 23:47:22 +01:00
|
|
|
import net.minecraft.util.math.BlockPos;
|
2016-07-03 21:57:33 +02:00
|
|
|
import net.minecraft.util.text.ITextComponent;
|
2017-07-28 22:17:52 +02:00
|
|
|
import net.minecraft.util.text.TextComponentTranslation;
|
2015-03-07 02:23:31 +01:00
|
|
|
import net.minecraft.world.World;
|
2016-06-05 02:16:52 +02:00
|
|
|
import net.minecraftforge.common.capabilities.Capability;
|
2016-11-26 08:58:42 +01:00
|
|
|
import net.minecraftforge.energy.CapabilityEnergy;
|
|
|
|
import net.minecraftforge.energy.IEnergyStorage;
|
2016-06-05 02:16:52 +02:00
|
|
|
import net.minecraftforge.fluids.capability.CapabilityFluidHandler;
|
|
|
|
import net.minecraftforge.fluids.capability.IFluidHandler;
|
2016-01-17 20:46:51 +01:00
|
|
|
import net.minecraftforge.fml.common.network.NetworkRegistry;
|
2016-01-07 18:20:59 +01:00
|
|
|
import net.minecraftforge.fml.common.registry.GameRegistry;
|
2016-12-04 00:10:52 +01:00
|
|
|
import net.minecraftforge.items.CapabilityItemHandler;
|
|
|
|
import net.minecraftforge.items.IItemHandler;
|
2014-12-12 15:40:01 +01:00
|
|
|
|
2016-01-07 23:42:42 +01:00
|
|
|
public abstract class TileEntityBase extends TileEntity implements ITickable{
|
2015-06-15 22:06:07 +02:00
|
|
|
|
2016-07-07 17:59:45 +02:00
|
|
|
public final String name;
|
2016-06-01 00:39:35 +02:00
|
|
|
public boolean isRedstonePowered;
|
2016-07-02 15:01:46 +02:00
|
|
|
public boolean isPulseMode;
|
2016-11-27 23:04:26 +01:00
|
|
|
public boolean stopFromDropping;
|
2016-12-18 17:50:31 +01:00
|
|
|
protected int ticksElapsed;
|
2016-09-09 18:40:09 +02:00
|
|
|
protected TileEntity[] tilesAround = new TileEntity[6];
|
2016-10-29 12:00:00 +02:00
|
|
|
protected boolean hasSavedDataOnChangeOrWorldStart;
|
2016-09-09 18:40:09 +02:00
|
|
|
|
2016-05-06 23:23:29 +02:00
|
|
|
public TileEntityBase(String name){
|
2016-07-03 21:57:33 +02:00
|
|
|
this.name = name;
|
2016-05-06 23:23:29 +02:00
|
|
|
}
|
|
|
|
|
2014-12-18 19:24:06 +01:00
|
|
|
public static void init(){
|
2015-07-01 21:32:48 +02:00
|
|
|
ModUtil.LOGGER.info("Registering TileEntities...");
|
2015-11-14 21:27:36 +01:00
|
|
|
|
2016-10-30 19:30:19 +01:00
|
|
|
register(TileEntityCompost.class);
|
|
|
|
register(TileEntityFeeder.class);
|
|
|
|
register(TileEntityGiantChest.class);
|
|
|
|
register(TileEntityGiantChestMedium.class);
|
|
|
|
register(TileEntityGiantChestLarge.class);
|
|
|
|
register(TileEntityGrinder.class);
|
|
|
|
register(TileEntityFurnaceDouble.class);
|
|
|
|
register(TileEntityInputter.class);
|
|
|
|
register(TileEntityFishingNet.class);
|
|
|
|
register(TileEntityFurnaceSolar.class);
|
|
|
|
register(TileEntityHeatCollector.class);
|
|
|
|
register(TileEntityItemRepairer.class);
|
|
|
|
register(TileEntityBreaker.class);
|
|
|
|
register(TileEntityDropper.class);
|
|
|
|
register(TileEntityInputterAdvanced.class);
|
|
|
|
register(TileEntityPlacer.class);
|
|
|
|
register(TileEntityGrinderDouble.class);
|
|
|
|
register(TileEntityCanolaPress.class);
|
|
|
|
register(TileEntityFermentingBarrel.class);
|
|
|
|
register(TileEntityOilGenerator.class);
|
|
|
|
register(TileEntityCoalGenerator.class);
|
|
|
|
register(TileEntityPhantomItemface.class);
|
|
|
|
register(TileEntityPhantomLiquiface.class);
|
|
|
|
register(TileEntityPhantomEnergyface.class);
|
|
|
|
register(TileEntityPlayerInterface.class);
|
|
|
|
register(TileEntityPhantomPlacer.class);
|
|
|
|
register(TileEntityPhantomBreaker.class);
|
|
|
|
register(TileEntityFluidCollector.class);
|
|
|
|
register(TileEntityFluidPlacer.class);
|
|
|
|
register(TileEntityLavaFactoryController.class);
|
|
|
|
register(TileEntityCoffeeMachine.class);
|
|
|
|
register(TileEntityPhantomBooster.class);
|
|
|
|
register(TileEntityEnergizer.class);
|
|
|
|
register(TileEntityEnervator.class);
|
|
|
|
register(TileEntityXPSolidifier.class);
|
|
|
|
register(TileEntitySmileyCloud.class);
|
|
|
|
register(TileEntityLeafGenerator.class);
|
|
|
|
register(TileEntityDirectionalBreaker.class);
|
|
|
|
register(TileEntityRangedCollector.class);
|
|
|
|
register(TileEntityAtomicReconstructor.class);
|
|
|
|
register(TileEntityMiner.class);
|
|
|
|
register(TileEntityFireworkBox.class);
|
|
|
|
register(TileEntityPhantomRedstoneface.class);
|
|
|
|
register(TileEntityLaserRelayItem.class);
|
|
|
|
register(TileEntityLaserRelayEnergy.class);
|
2016-07-14 16:44:01 +02:00
|
|
|
register(TileEntityLaserRelayEnergyAdvanced.class);
|
|
|
|
register(TileEntityLaserRelayEnergyExtreme.class);
|
2016-10-30 19:30:19 +01:00
|
|
|
register(TileEntityLaserRelayItemWhitelist.class);
|
|
|
|
register(TileEntityItemViewer.class);
|
|
|
|
register(TileEntityDisplayStand.class);
|
|
|
|
register(TileEntityShockSuppressor.class);
|
2016-08-03 04:01:47 +02:00
|
|
|
register(TileEntityEmpowerer.class);
|
2016-09-01 20:41:50 +02:00
|
|
|
register(TileEntityLaserRelayFluids.class);
|
2016-09-14 21:42:03 +02:00
|
|
|
register(TileEntityBioReactor.class);
|
2016-10-31 18:03:18 +01:00
|
|
|
register(TileEntityFarmer.class);
|
2016-12-18 13:27:14 +01:00
|
|
|
register(TileEntityItemViewerHopping.class);
|
2016-12-18 17:28:29 +01:00
|
|
|
register(TileEntityBatteryBox.class);
|
2014-12-18 19:24:06 +01:00
|
|
|
}
|
2015-03-07 02:23:31 +01:00
|
|
|
|
2016-10-30 19:30:19 +01:00
|
|
|
private static void register(Class<? extends TileEntityBase> tileClass){
|
2016-07-03 21:57:33 +02:00
|
|
|
try{
|
|
|
|
//This is hacky and dirty but it works so whatever
|
|
|
|
String name = ModUtil.MOD_ID+":"+tileClass.newInstance().name;
|
2016-10-30 19:30:19 +01:00
|
|
|
GameRegistry.registerTileEntity(tileClass, name);
|
2016-07-03 21:57:33 +02:00
|
|
|
}
|
|
|
|
catch(Exception e){
|
|
|
|
ModUtil.LOGGER.fatal("Registering a TileEntity failed!", e);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2015-10-18 15:28:06 +02:00
|
|
|
@Override
|
2016-09-01 17:08:34 +02:00
|
|
|
public final NBTTagCompound writeToNBT(NBTTagCompound compound){
|
2016-07-02 15:01:46 +02:00
|
|
|
this.writeSyncableNBT(compound, NBTType.SAVE_TILE);
|
2016-05-26 13:10:14 +02:00
|
|
|
return compound;
|
2015-10-18 15:28:06 +02:00
|
|
|
}
|
|
|
|
|
2015-10-03 10:16:18 +02:00
|
|
|
@Override
|
2016-09-01 17:08:34 +02:00
|
|
|
public final void readFromNBT(NBTTagCompound compound){
|
|
|
|
this.readSyncableNBT(compound, NBTType.SAVE_TILE);
|
2015-10-03 10:16:18 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
@Override
|
2016-09-01 17:08:34 +02:00
|
|
|
public final SPacketUpdateTileEntity getUpdatePacket(){
|
|
|
|
NBTTagCompound compound = new NBTTagCompound();
|
|
|
|
this.writeSyncableNBT(compound, NBTType.SYNC);
|
|
|
|
return new SPacketUpdateTileEntity(this.pos, -1, compound);
|
2015-10-03 10:16:18 +02:00
|
|
|
}
|
|
|
|
|
2016-09-01 17:08:34 +02:00
|
|
|
@Override
|
|
|
|
public final void onDataPacket(NetworkManager net, SPacketUpdateTileEntity pkt){
|
|
|
|
this.readSyncableNBT(pkt.getNbtCompound(), NBTType.SYNC);
|
2016-02-01 17:49:55 +01:00
|
|
|
}
|
|
|
|
|
2016-05-26 13:10:14 +02:00
|
|
|
@Override
|
2016-09-01 17:08:34 +02:00
|
|
|
public final NBTTagCompound getUpdateTag(){
|
2016-08-14 11:43:59 +02:00
|
|
|
NBTTagCompound compound = new NBTTagCompound();
|
|
|
|
this.writeSyncableNBT(compound, NBTType.SYNC);
|
|
|
|
return compound;
|
2016-02-01 17:49:55 +01:00
|
|
|
}
|
|
|
|
|
2016-06-04 00:26:33 +02:00
|
|
|
@Override
|
2016-08-14 11:43:59 +02:00
|
|
|
public final void handleUpdateTag(NBTTagCompound compound){
|
2016-09-01 17:08:34 +02:00
|
|
|
this.readSyncableNBT(compound, NBTType.SYNC);
|
2016-06-04 00:26:33 +02:00
|
|
|
}
|
|
|
|
|
2016-09-01 17:08:34 +02:00
|
|
|
public final void sendUpdate(){
|
2016-11-27 19:04:22 +01:00
|
|
|
if(this.world != null && !this.world.isRemote){
|
2016-09-01 17:08:34 +02:00
|
|
|
NBTTagCompound compound = new NBTTagCompound();
|
|
|
|
this.writeSyncableNBT(compound, NBTType.SYNC);
|
|
|
|
|
|
|
|
NBTTagCompound data = new NBTTagCompound();
|
|
|
|
data.setTag("Data", compound);
|
|
|
|
data.setInteger("X", this.pos.getX());
|
|
|
|
data.setInteger("Y", this.pos.getY());
|
|
|
|
data.setInteger("Z", this.pos.getZ());
|
2016-12-04 00:10:52 +01:00
|
|
|
PacketHandler.theNetwork.sendToAllAround(new PacketServerToClient(data, PacketHandler.TILE_ENTITY_HANDLER), new NetworkRegistry.TargetPoint(this.world.provider.getDimension(), this.getPos().getX(), this.getPos().getY(), this.getPos().getZ(), 64));
|
2016-09-01 17:08:34 +02:00
|
|
|
}
|
2016-07-06 21:56:15 +02:00
|
|
|
}
|
|
|
|
|
2016-07-02 15:01:46 +02:00
|
|
|
public void writeSyncableNBT(NBTTagCompound compound, NBTType type){
|
2016-09-01 20:41:50 +02:00
|
|
|
if(type != NBTType.SAVE_BLOCK){
|
|
|
|
super.writeToNBT(compound);
|
|
|
|
}
|
2016-08-14 11:43:59 +02:00
|
|
|
|
2016-07-02 15:01:46 +02:00
|
|
|
if(type == NBTType.SAVE_TILE){
|
2016-05-26 13:10:14 +02:00
|
|
|
compound.setBoolean("Redstone", this.isRedstonePowered);
|
2016-07-22 20:23:51 +02:00
|
|
|
compound.setInteger("TicksElapsed", this.ticksElapsed);
|
2016-11-27 23:04:26 +01:00
|
|
|
compound.setBoolean("StopDrop", this.stopFromDropping);
|
2016-05-26 13:10:14 +02:00
|
|
|
}
|
2016-07-02 15:01:46 +02:00
|
|
|
if(this.isRedstoneToggle() && (type != NBTType.SAVE_BLOCK || this.isPulseMode)){
|
|
|
|
compound.setBoolean("IsPulseMode", this.isPulseMode);
|
2015-12-21 22:18:33 +01:00
|
|
|
}
|
2015-12-01 19:48:09 +01:00
|
|
|
}
|
|
|
|
|
2016-07-02 15:01:46 +02:00
|
|
|
public void readSyncableNBT(NBTTagCompound compound, NBTType type){
|
2016-09-01 20:41:50 +02:00
|
|
|
if(type != NBTType.SAVE_BLOCK){
|
|
|
|
super.readFromNBT(compound);
|
|
|
|
}
|
2016-08-14 11:43:59 +02:00
|
|
|
|
2016-07-02 15:01:46 +02:00
|
|
|
if(type == NBTType.SAVE_TILE){
|
2016-05-26 13:10:14 +02:00
|
|
|
this.isRedstonePowered = compound.getBoolean("Redstone");
|
2016-07-22 20:23:51 +02:00
|
|
|
this.ticksElapsed = compound.getInteger("TicksElapsed");
|
2016-11-27 23:04:26 +01:00
|
|
|
this.stopFromDropping = compound.getBoolean("StopDrop");
|
2016-05-26 13:10:14 +02:00
|
|
|
}
|
2016-07-02 15:01:46 +02:00
|
|
|
if(this.isRedstoneToggle()){
|
|
|
|
this.isPulseMode = compound.getBoolean("IsPulseMode");
|
2015-12-21 22:18:33 +01:00
|
|
|
}
|
2015-10-21 00:22:50 +02:00
|
|
|
}
|
2015-10-18 15:31:01 +02:00
|
|
|
|
2016-02-01 17:49:55 +01:00
|
|
|
@Override
|
2016-09-01 17:08:34 +02:00
|
|
|
public boolean shouldRefresh(World world, BlockPos pos, IBlockState oldState, IBlockState newState){
|
|
|
|
return !oldState.getBlock().isAssociatedBlock(newState.getBlock());
|
|
|
|
}
|
|
|
|
|
2017-07-28 22:17:52 +02:00
|
|
|
public String getNameForTranslation(){
|
|
|
|
return "container."+ModUtil.MOD_ID+"."+this.name+".name";
|
2016-11-20 13:46:35 +01:00
|
|
|
}
|
|
|
|
|
2016-09-01 17:08:34 +02:00
|
|
|
@Override
|
|
|
|
public ITextComponent getDisplayName(){
|
2017-07-28 22:17:52 +02:00
|
|
|
return new TextComponentTranslation(this.getNameForTranslation());
|
2016-09-01 17:08:34 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
@Override
|
|
|
|
public final void update(){
|
2016-02-01 17:49:55 +01:00
|
|
|
this.updateEntity();
|
|
|
|
}
|
|
|
|
|
2016-11-28 12:51:45 +01:00
|
|
|
public int getComparatorStrength(){
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
2016-02-01 17:49:55 +01:00
|
|
|
public void updateEntity(){
|
|
|
|
this.ticksElapsed++;
|
2016-06-17 13:25:15 +02:00
|
|
|
|
2016-11-26 21:32:27 +01:00
|
|
|
if(!this.world.isRemote){
|
2016-08-31 20:16:36 +02:00
|
|
|
if(this instanceof ISharingEnergyProvider){
|
|
|
|
ISharingEnergyProvider provider = (ISharingEnergyProvider)this;
|
|
|
|
if(provider.doesShareEnergy()){
|
2016-08-31 21:14:48 +02:00
|
|
|
int total = provider.getEnergyToSplitShare();
|
|
|
|
if(total > 0){
|
|
|
|
EnumFacing[] sides = provider.getEnergyShareSides();
|
|
|
|
|
|
|
|
int amount = total/sides.length;
|
|
|
|
if(amount <= 0){
|
|
|
|
amount = total;
|
|
|
|
}
|
2016-09-09 18:40:09 +02:00
|
|
|
|
2016-08-31 21:14:48 +02:00
|
|
|
for(EnumFacing side : sides){
|
2016-09-09 18:40:09 +02:00
|
|
|
TileEntity tile = this.tilesAround[side.ordinal()];
|
2016-12-18 17:28:29 +01:00
|
|
|
if(tile != null && provider.canShareTo(tile)){
|
2016-09-09 18:40:09 +02:00
|
|
|
WorldUtil.doEnergyInteraction(this, tile, side, amount);
|
|
|
|
}
|
2016-08-31 21:14:48 +02:00
|
|
|
}
|
2016-08-31 20:16:36 +02:00
|
|
|
}
|
|
|
|
}
|
2016-06-17 13:25:15 +02:00
|
|
|
}
|
|
|
|
|
2016-08-31 20:16:36 +02:00
|
|
|
if(this instanceof ISharingFluidHandler){
|
|
|
|
ISharingFluidHandler handler = (ISharingFluidHandler)this;
|
|
|
|
if(handler.doesShareFluid()){
|
2016-11-19 21:11:17 +01:00
|
|
|
int total = handler.getMaxFluidAmountToSplitShare();
|
2016-08-31 21:14:48 +02:00
|
|
|
if(total > 0){
|
|
|
|
EnumFacing[] sides = handler.getFluidShareSides();
|
|
|
|
|
|
|
|
int amount = total/sides.length;
|
|
|
|
if(amount <= 0){
|
|
|
|
amount = total;
|
|
|
|
}
|
2016-09-09 18:40:09 +02:00
|
|
|
|
2016-08-31 21:14:48 +02:00
|
|
|
for(EnumFacing side : sides){
|
2016-09-09 18:40:09 +02:00
|
|
|
TileEntity tile = this.tilesAround[side.ordinal()];
|
|
|
|
if(tile != null){
|
|
|
|
WorldUtil.doFluidInteraction(this, tile, side, amount);
|
|
|
|
}
|
2016-08-31 21:14:48 +02:00
|
|
|
}
|
2016-08-31 20:16:36 +02:00
|
|
|
}
|
|
|
|
}
|
2016-06-17 13:25:15 +02:00
|
|
|
}
|
2016-09-09 18:40:09 +02:00
|
|
|
|
2016-10-29 12:00:00 +02:00
|
|
|
if(!this.hasSavedDataOnChangeOrWorldStart){
|
|
|
|
if(this.shouldSaveDataOnChangeOrWorldStart()){
|
|
|
|
this.saveDataOnChangeOrWorldStart();
|
2016-09-09 18:40:09 +02:00
|
|
|
}
|
|
|
|
|
2016-10-29 12:00:00 +02:00
|
|
|
this.hasSavedDataOnChangeOrWorldStart = true;
|
2016-09-09 18:40:09 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2016-10-29 12:00:00 +02:00
|
|
|
public void saveDataOnChangeOrWorldStart(){
|
2016-09-09 18:40:09 +02:00
|
|
|
for(EnumFacing side : EnumFacing.values()){
|
2017-01-18 14:26:56 +01:00
|
|
|
BlockPos pos = this.pos.offset(side);
|
|
|
|
if(this.world.isBlockLoaded(pos)){
|
|
|
|
this.tilesAround[side.ordinal()] = this.world.getTileEntity(pos);
|
|
|
|
}
|
2016-06-17 13:25:15 +02:00
|
|
|
}
|
2016-02-01 17:49:55 +01:00
|
|
|
}
|
|
|
|
|
2016-10-29 12:00:00 +02:00
|
|
|
public boolean shouldSaveDataOnChangeOrWorldStart(){
|
2016-09-09 18:40:09 +02:00
|
|
|
return this instanceof ISharingEnergyProvider || this instanceof ISharingFluidHandler;
|
|
|
|
}
|
|
|
|
|
2016-05-26 13:10:14 +02:00
|
|
|
public void setRedstonePowered(boolean powered){
|
2015-12-19 10:30:39 +01:00
|
|
|
this.isRedstonePowered = powered;
|
2015-12-25 15:24:40 +01:00
|
|
|
this.markDirty();
|
2015-12-19 10:30:39 +01:00
|
|
|
}
|
|
|
|
|
2016-05-06 23:23:29 +02:00
|
|
|
public boolean canPlayerUse(EntityPlayer player){
|
2016-11-26 21:32:27 +01:00
|
|
|
return player.getDistanceSq(this.getPos().getX()+0.5D, this.pos.getY()+0.5D, this.pos.getZ()+0.5D) <= 64 && !this.isInvalid() && this.world.getTileEntity(this.pos) == this;
|
2016-05-06 23:23:29 +02:00
|
|
|
}
|
|
|
|
|
2016-05-26 13:10:14 +02:00
|
|
|
protected boolean sendUpdateWithInterval(){
|
2015-12-01 19:48:09 +01:00
|
|
|
if(this.ticksElapsed%ConfigIntValues.TILE_ENTITY_UPDATE_INTERVAL.getValue() == 0){
|
2015-12-01 17:28:50 +01:00
|
|
|
this.sendUpdate();
|
2015-11-19 22:13:52 +01:00
|
|
|
return true;
|
|
|
|
}
|
|
|
|
else{
|
|
|
|
return false;
|
2015-11-18 23:11:24 +01:00
|
|
|
}
|
2015-10-18 15:28:06 +02:00
|
|
|
}
|
2015-12-01 17:28:50 +01:00
|
|
|
|
2016-06-05 02:16:52 +02:00
|
|
|
@Override
|
|
|
|
public boolean hasCapability(Capability<?> capability, EnumFacing facing){
|
|
|
|
return this.getCapability(capability, facing) != null;
|
|
|
|
}
|
|
|
|
|
2017-08-02 14:01:41 +02:00
|
|
|
@SuppressWarnings("unchecked")
|
|
|
|
@Override
|
2016-06-05 02:16:52 +02:00
|
|
|
public <T> T getCapability(Capability<T> capability, EnumFacing facing){
|
2016-12-04 00:10:52 +01:00
|
|
|
if(capability == CapabilityItemHandler.ITEM_HANDLER_CAPABILITY){
|
|
|
|
IItemHandler handler = this.getItemHandler(facing);
|
|
|
|
if(handler != null){
|
|
|
|
return (T)handler;
|
|
|
|
}
|
|
|
|
}
|
2016-12-06 08:19:32 +01:00
|
|
|
else if(capability == CapabilityFluidHandler.FLUID_HANDLER_CAPABILITY){
|
2016-06-05 02:16:52 +02:00
|
|
|
IFluidHandler tank = this.getFluidHandler(facing);
|
|
|
|
if(tank != null){
|
|
|
|
return (T)tank;
|
|
|
|
}
|
|
|
|
}
|
2016-11-26 08:58:42 +01:00
|
|
|
else if(capability == CapabilityEnergy.ENERGY){
|
|
|
|
IEnergyStorage storage = this.getEnergyStorage(facing);
|
|
|
|
if(storage != null){
|
|
|
|
return (T)storage;
|
|
|
|
}
|
|
|
|
}
|
2016-06-05 02:16:52 +02:00
|
|
|
return super.getCapability(capability, facing);
|
|
|
|
}
|
|
|
|
|
|
|
|
public IFluidHandler getFluidHandler(EnumFacing facing){
|
|
|
|
return null;
|
|
|
|
}
|
2016-07-02 15:01:46 +02:00
|
|
|
|
2016-11-26 08:58:42 +01:00
|
|
|
public IEnergyStorage getEnergyStorage(EnumFacing facing){
|
|
|
|
return null;
|
|
|
|
}
|
|
|
|
|
2016-12-04 00:10:52 +01:00
|
|
|
public IItemHandler getItemHandler(EnumFacing facing){
|
|
|
|
return null;
|
|
|
|
}
|
|
|
|
|
2016-07-02 15:01:46 +02:00
|
|
|
public boolean isRedstoneToggle(){
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
|
|
|
public void activateOnPulse(){
|
|
|
|
|
|
|
|
}
|
|
|
|
|
2016-12-18 17:28:29 +01:00
|
|
|
public boolean respondsToPulses(){
|
|
|
|
return this.isRedstoneToggle() && this.isPulseMode;
|
|
|
|
}
|
|
|
|
|
2016-07-02 15:01:46 +02:00
|
|
|
public enum NBTType{
|
|
|
|
SAVE_TILE,
|
|
|
|
SYNC,
|
|
|
|
SAVE_BLOCK
|
|
|
|
}
|
2015-03-07 02:23:31 +01:00
|
|
|
}
|