Fixed Phantom Energyface not working for certain tesla machines and Liquiface crashing with capabilities

Closes #226
This commit is contained in:
Ellpeck 2016-09-02 08:33:54 +02:00
parent 340d7cf780
commit 41019417f4
2 changed files with 125 additions and 23 deletions

View file

@ -110,12 +110,21 @@ public class TileEntityPhantomEnergyface extends TileEntityPhantomface implement
public boolean isBoundThingInRange(){ public boolean isBoundThingInRange(){
if(super.isBoundThingInRange()){ if(super.isBoundThingInRange()){
TileEntity tile = this.worldObj.getTileEntity(this.boundPosition); TileEntity tile = this.worldObj.getTileEntity(this.boundPosition);
return tile != null && (tile instanceof IEnergyHandler || (ActuallyAdditions.teslaLoaded && tile.hasCapability(TeslaUtil.teslaHolder, null))); if(tile != null){
if(tile instanceof IEnergyHandler){
return true;
}
else if(ActuallyAdditions.teslaLoaded){
for(EnumFacing facing : EnumFacing.values()){
if(tile.hasCapability(TeslaUtil.teslaHolder, facing)){
return true;
}
}
}
}
} }
else{
return false; return false;
} }
}
@Override @Override
public boolean canConnectEnergy(EnumFacing from){ public boolean canConnectEnergy(EnumFacing from){

View file

@ -13,8 +13,12 @@ package de.ellpeck.actuallyadditions.mod.tile;
import de.ellpeck.actuallyadditions.mod.blocks.BlockPhantom; import de.ellpeck.actuallyadditions.mod.blocks.BlockPhantom;
import net.minecraft.tileentity.TileEntity; import net.minecraft.tileentity.TileEntity;
import net.minecraft.util.EnumFacing; import net.minecraft.util.EnumFacing;
import net.minecraftforge.fluids.*; import net.minecraftforge.fluids.Fluid;
import net.minecraftforge.fluids.FluidStack;
import net.minecraftforge.fluids.FluidTankInfo;
import net.minecraftforge.fluids.capability.CapabilityFluidHandler; import net.minecraftforge.fluids.capability.CapabilityFluidHandler;
import net.minecraftforge.fluids.capability.IFluidHandler;
import net.minecraftforge.fluids.capability.IFluidTankProperties;
public class TileEntityPhantomLiquiface extends TileEntityPhantomface implements ISharingFluidHandler{ public class TileEntityPhantomLiquiface extends TileEntityPhantomface implements ISharingFluidHandler{
@ -28,7 +32,16 @@ public class TileEntityPhantomLiquiface extends TileEntityPhantomface implements
if(super.isBoundThingInRange()){ if(super.isBoundThingInRange()){
TileEntity tile = this.worldObj.getTileEntity(this.boundPosition); TileEntity tile = this.worldObj.getTileEntity(this.boundPosition);
if(tile != null){ if(tile != null){
return tile instanceof IFluidHandler || tile.hasCapability(CapabilityFluidHandler.FLUID_HANDLER_CAPABILITY, null); if(tile instanceof net.minecraftforge.fluids.IFluidHandler){
return true;
}
else{
for(EnumFacing facing : EnumFacing.values()){
if(tile.hasCapability(CapabilityFluidHandler.FLUID_HANDLER_CAPABILITY, facing)){
return true;
}
}
}
} }
} }
return false; return false;
@ -37,7 +50,20 @@ public class TileEntityPhantomLiquiface extends TileEntityPhantomface implements
@Override @Override
public int fill(EnumFacing from, FluidStack resource, boolean doFill){ public int fill(EnumFacing from, FluidStack resource, boolean doFill){
if(this.isBoundThingInRange()){ if(this.isBoundThingInRange()){
return this.getHandler().fill(from, resource, doFill); TileEntity tile = this.worldObj.getTileEntity(this.boundPosition);
if(tile != null){
if(tile instanceof net.minecraftforge.fluids.IFluidHandler){
return ((net.minecraftforge.fluids.IFluidHandler)tile).fill(from, resource, doFill);
}
else{
if(tile.hasCapability(CapabilityFluidHandler.FLUID_HANDLER_CAPABILITY, from)){
IFluidHandler cap = tile.getCapability(CapabilityFluidHandler.FLUID_HANDLER_CAPABILITY, from);
if(cap != null){
return cap.fill(resource, doFill);
}
}
}
}
} }
return 0; return 0;
} }
@ -45,7 +71,20 @@ public class TileEntityPhantomLiquiface extends TileEntityPhantomface implements
@Override @Override
public FluidStack drain(EnumFacing from, FluidStack resource, boolean doDrain){ public FluidStack drain(EnumFacing from, FluidStack resource, boolean doDrain){
if(this.isBoundThingInRange()){ if(this.isBoundThingInRange()){
return this.getHandler().drain(from, resource, doDrain); TileEntity tile = this.worldObj.getTileEntity(this.boundPosition);
if(tile != null){
if(tile instanceof net.minecraftforge.fluids.IFluidHandler){
return ((net.minecraftforge.fluids.IFluidHandler)tile).drain(from, resource, doDrain);
}
else{
if(tile.hasCapability(CapabilityFluidHandler.FLUID_HANDLER_CAPABILITY, from)){
IFluidHandler cap = tile.getCapability(CapabilityFluidHandler.FLUID_HANDLER_CAPABILITY, from);
if(cap != null){
return cap.drain(resource, doDrain);
}
}
}
}
} }
return null; return null;
} }
@ -53,37 +92,91 @@ public class TileEntityPhantomLiquiface extends TileEntityPhantomface implements
@Override @Override
public FluidStack drain(EnumFacing from, int maxDrain, boolean doDrain){ public FluidStack drain(EnumFacing from, int maxDrain, boolean doDrain){
if(this.isBoundThingInRange()){ if(this.isBoundThingInRange()){
return this.getHandler().drain(from, maxDrain, doDrain); TileEntity tile = this.worldObj.getTileEntity(this.boundPosition);
if(tile != null){
if(tile instanceof net.minecraftforge.fluids.IFluidHandler){
return ((net.minecraftforge.fluids.IFluidHandler)tile).drain(from, maxDrain, doDrain);
}
else{
if(tile.hasCapability(CapabilityFluidHandler.FLUID_HANDLER_CAPABILITY, from)){
IFluidHandler cap = tile.getCapability(CapabilityFluidHandler.FLUID_HANDLER_CAPABILITY, from);
if(cap != null){
return cap.drain(maxDrain, doDrain);
}
}
}
}
} }
return null; return null;
} }
@Override @Override
public boolean canFill(EnumFacing from, Fluid fluid){ public boolean canFill(EnumFacing from, Fluid fluid){
return this.isBoundThingInRange() && this.getHandler().canFill(from, fluid); if(this.isBoundThingInRange()){
TileEntity tile = this.worldObj.getTileEntity(this.boundPosition);
if(tile != null){
if(tile instanceof net.minecraftforge.fluids.IFluidHandler){
return ((net.minecraftforge.fluids.IFluidHandler)tile).canFill(from, fluid);
}
else{
if(tile.hasCapability(CapabilityFluidHandler.FLUID_HANDLER_CAPABILITY, from)){
IFluidHandler cap = tile.getCapability(CapabilityFluidHandler.FLUID_HANDLER_CAPABILITY, from);
if(cap != null){
FluidStack stack = new FluidStack(fluid, 1);
IFluidTankProperties[] props = cap.getTankProperties();
if(props != null){
for(IFluidTankProperties prop : props){
if(prop.canFillFluidType(stack)){
return true;
}
}
}
}
}
}
}
}
return false;
} }
@Override @Override
public boolean canDrain(EnumFacing from, Fluid fluid){ public boolean canDrain(EnumFacing from, Fluid fluid){
return this.isBoundThingInRange() && this.getHandler().canDrain(from, fluid); if(this.isBoundThingInRange()){
TileEntity tile = this.worldObj.getTileEntity(this.boundPosition);
if(tile != null){
if(tile instanceof net.minecraftforge.fluids.IFluidHandler){
return ((net.minecraftforge.fluids.IFluidHandler)tile).canDrain(from, fluid);
}
else{
if(tile.hasCapability(CapabilityFluidHandler.FLUID_HANDLER_CAPABILITY, from)){
IFluidHandler cap = tile.getCapability(CapabilityFluidHandler.FLUID_HANDLER_CAPABILITY, from);
if(cap != null){
FluidStack stack = new FluidStack(fluid, 1);
IFluidTankProperties[] props = cap.getTankProperties();
if(props != null){
for(IFluidTankProperties prop : props){
if(prop.canDrainFluidType(stack)){
return true;
}
}
}
}
}
}
}
}
return false;
} }
@Override @Override
public FluidTankInfo[] getTankInfo(EnumFacing from){ public FluidTankInfo[] getTankInfo(EnumFacing from){
if(this.isBoundThingInRange()){ TileEntity tile = this.worldObj.getTileEntity(this.boundPosition);
return this.getHandler().getTankInfo(from); if(tile instanceof net.minecraftforge.fluids.IFluidHandler){
return ((net.minecraftforge.fluids.IFluidHandler)tile).getTankInfo(from);
} }
else{
return new FluidTankInfo[0]; return new FluidTankInfo[0];
} }
public IFluidHandler getHandler(){
if(this.boundPosition != null){
TileEntity tile = this.worldObj.getTileEntity(this.boundPosition);
if(tile instanceof IFluidHandler){
return (IFluidHandler)tile;
}
}
return null;
} }
@Override @Override