P2P Tunnel improvements (#3039)
* Fix P2P Tunnels randomly resetting to ME * Allow one way push and pull. Outputs can pull from the input side, input can push into outputs.
This commit is contained in:
parent
80eaa032b9
commit
8e4265aa33
2 changed files with 155 additions and 157 deletions
|
@ -26,8 +26,6 @@ import javax.annotation.Nullable;
|
||||||
|
|
||||||
import net.minecraft.item.ItemStack;
|
import net.minecraft.item.ItemStack;
|
||||||
import net.minecraft.tileentity.TileEntity;
|
import net.minecraft.tileentity.TileEntity;
|
||||||
import net.minecraft.util.math.BlockPos;
|
|
||||||
import net.minecraft.world.IBlockAccess;
|
|
||||||
import net.minecraftforge.common.capabilities.Capability;
|
import net.minecraftforge.common.capabilities.Capability;
|
||||||
import net.minecraftforge.energy.IEnergyStorage;
|
import net.minecraftforge.energy.IEnergyStorage;
|
||||||
|
|
||||||
|
@ -38,17 +36,12 @@ import appeng.items.parts.PartModels;
|
||||||
import appeng.me.GridAccessException;
|
import appeng.me.GridAccessException;
|
||||||
|
|
||||||
|
|
||||||
/**
|
public class PartP2PFEPower extends PartP2PTunnel<PartP2PFEPower>
|
||||||
* @author GuntherDW
|
|
||||||
*/
|
|
||||||
public class PartP2PFEPower extends PartP2PTunnel<PartP2PFEPower> implements IEnergyStorage
|
|
||||||
{
|
{
|
||||||
private static final P2PModels MODELS = new P2PModels( "part/p2p/p2p_tunnel_fe" );
|
private static final P2PModels MODELS = new P2PModels( "part/p2p/p2p_tunnel_fe" );
|
||||||
private static final IEnergyStorage NULL_ENERGY_STORAGE = new NullEnergyStorage();
|
private static final IEnergyStorage NULL_ENERGY_STORAGE = new NullEnergyStorage();
|
||||||
|
private final IEnergyStorage inputHandler = new InputEnergyStorage();
|
||||||
private boolean cachedTarget = false;
|
private final IEnergyStorage outputHandler = new OutputEnergyStorage();
|
||||||
|
|
||||||
private IEnergyStorage outputTarget;
|
|
||||||
|
|
||||||
public PartP2PFEPower( ItemStack is )
|
public PartP2PFEPower( ItemStack is )
|
||||||
{
|
{
|
||||||
|
@ -73,29 +66,62 @@ public class PartP2PFEPower extends PartP2PTunnel<PartP2PFEPower> implements IEn
|
||||||
this.getHost().notifyNeighbors();
|
this.getHost().notifyNeighbors();
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
private IEnergyStorage getAttachedEnergyStorage()
|
||||||
public void onNeighborChanged( IBlockAccess w, BlockPos pos, BlockPos neighbor )
|
|
||||||
{
|
{
|
||||||
super.onNeighborChanged( w, pos, neighbor );
|
if( this.isActive() )
|
||||||
|
{
|
||||||
|
final TileEntity self = this.getTile();
|
||||||
|
final TileEntity te = self.getWorld().getTileEntity( self.getPos().offset( this.getSide().getFacing() ) );
|
||||||
|
|
||||||
this.cachedTarget = false;
|
if( te != null && te.hasCapability( Capabilities.FORGE_ENERGY, this.getSide().getOpposite().getFacing() ) )
|
||||||
|
{
|
||||||
|
return te.getCapability( Capabilities.FORGE_ENERGY, this.getSide().getOpposite().getFacing() );
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return NULL_ENERGY_STORAGE;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public boolean hasCapability( @Nonnull Capability<?> capability )
|
||||||
|
{
|
||||||
|
if( capability == Capabilities.FORGE_ENERGY )
|
||||||
|
{
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
return super.hasCapability( capability );
|
||||||
|
}
|
||||||
|
|
||||||
|
@Nullable
|
||||||
|
@Override
|
||||||
|
public <T> T getCapability( @Nonnull Capability<T> capability )
|
||||||
|
{
|
||||||
|
if( capability == Capabilities.FORGE_ENERGY )
|
||||||
|
{
|
||||||
|
if( this.isOutput() )
|
||||||
|
{
|
||||||
|
return (T) this.outputHandler;
|
||||||
|
}
|
||||||
|
return (T) this.inputHandler;
|
||||||
|
}
|
||||||
|
return super.getCapability( capability );
|
||||||
|
}
|
||||||
|
|
||||||
|
private class InputEnergyStorage implements IEnergyStorage
|
||||||
|
{
|
||||||
|
@Override
|
||||||
|
public int extractEnergy( int maxExtract, boolean simulate )
|
||||||
|
{
|
||||||
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public int receiveEnergy( int maxReceive, boolean simulate )
|
public int receiveEnergy( int maxReceive, boolean simulate )
|
||||||
{
|
|
||||||
if( this.isOutput() )
|
|
||||||
{
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
if( this.isActive() )
|
|
||||||
{
|
{
|
||||||
int total = 0;
|
int total = 0;
|
||||||
|
|
||||||
try
|
try
|
||||||
{
|
{
|
||||||
final int outputTunnels = this.getOutputs().size();
|
final int outputTunnels = PartP2PFEPower.this.getOutputs().size();
|
||||||
|
|
||||||
if( outputTunnels == 0 )
|
if( outputTunnels == 0 )
|
||||||
{
|
{
|
||||||
|
@ -105,9 +131,9 @@ public class PartP2PFEPower extends PartP2PTunnel<PartP2PFEPower> implements IEn
|
||||||
final int amountPerOutput = maxReceive / outputTunnels;
|
final int amountPerOutput = maxReceive / outputTunnels;
|
||||||
int overflow = maxReceive % amountPerOutput;
|
int overflow = maxReceive % amountPerOutput;
|
||||||
|
|
||||||
for( PartP2PFEPower target : this.getOutputs() )
|
for( PartP2PFEPower target : PartP2PFEPower.this.getOutputs() )
|
||||||
{
|
{
|
||||||
final IEnergyStorage output = target.getOutput();
|
final IEnergyStorage output = target.getAttachedEnergyStorage();
|
||||||
final int toSend = amountPerOutput + overflow;
|
final int toSend = amountPerOutput + overflow;
|
||||||
final int received = output.receiveEnergy( toSend, simulate );
|
final int received = output.receiveEnergy( toSend, simulate );
|
||||||
|
|
||||||
|
@ -115,7 +141,7 @@ public class PartP2PFEPower extends PartP2PTunnel<PartP2PFEPower> implements IEn
|
||||||
total += received;
|
total += received;
|
||||||
}
|
}
|
||||||
|
|
||||||
this.queueTunnelDrain( PowerUnits.RF, total );
|
PartP2PFEPower.this.queueTunnelDrain( PowerUnits.RF, total );
|
||||||
}
|
}
|
||||||
catch( GridAccessException ignored )
|
catch( GridAccessException ignored )
|
||||||
{
|
{
|
||||||
|
@ -124,96 +150,6 @@ public class PartP2PFEPower extends PartP2PTunnel<PartP2PFEPower> implements IEn
|
||||||
return total;
|
return total;
|
||||||
}
|
}
|
||||||
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public int extractEnergy( int maxExtract, boolean simulate )
|
|
||||||
{
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
private IEnergyStorage getOutput()
|
|
||||||
{
|
|
||||||
if( this.isOutput() )
|
|
||||||
{
|
|
||||||
if( !this.cachedTarget )
|
|
||||||
{
|
|
||||||
final TileEntity self = this.getTile();
|
|
||||||
final TileEntity te = self.getWorld().getTileEntity( new BlockPos( self.getPos().getX() + this.getSide().xOffset, self.getPos()
|
|
||||||
.getY() + this.getSide().yOffset, self.getPos().getZ() + this.getSide().zOffset ) );
|
|
||||||
|
|
||||||
if( te != null && te.hasCapability( Capabilities.FORGE_ENERGY, this.getSide().getOpposite().getFacing() ) )
|
|
||||||
{
|
|
||||||
this.outputTarget = te.getCapability( Capabilities.FORGE_ENERGY, this.getSide().getOpposite().getFacing() );
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
this.outputTarget = null;
|
|
||||||
}
|
|
||||||
|
|
||||||
this.cachedTarget = true;
|
|
||||||
}
|
|
||||||
|
|
||||||
if( this.outputTarget != null && this.outputTarget.canReceive() )
|
|
||||||
{
|
|
||||||
return this.outputTarget;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
return NULL_ENERGY_STORAGE;
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public int getEnergyStored()
|
|
||||||
{
|
|
||||||
if( this.isOutput() || !this.isActive() )
|
|
||||||
{
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
int total = 0;
|
|
||||||
|
|
||||||
try
|
|
||||||
{
|
|
||||||
for( PartP2PFEPower t : this.getOutputs() )
|
|
||||||
{
|
|
||||||
total += t.getOutput().getEnergyStored();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
catch( GridAccessException e )
|
|
||||||
{
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
return total;
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public int getMaxEnergyStored()
|
|
||||||
{
|
|
||||||
if( this.isOutput() || !this.isActive() )
|
|
||||||
{
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
int total = 0;
|
|
||||||
|
|
||||||
try
|
|
||||||
{
|
|
||||||
for( PartP2PFEPower t : this.getOutputs() )
|
|
||||||
{
|
|
||||||
total += t.getOutput().getMaxEnergyStored();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
catch( GridAccessException e )
|
|
||||||
{
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
return total;
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public boolean canExtract()
|
public boolean canExtract()
|
||||||
{
|
{
|
||||||
|
@ -227,26 +163,83 @@ public class PartP2PFEPower extends PartP2PTunnel<PartP2PFEPower> implements IEn
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public boolean hasCapability( @Nonnull Capability<?> capability )
|
public int getMaxEnergyStored()
|
||||||
{
|
{
|
||||||
if( capability == Capabilities.FORGE_ENERGY )
|
int total = 0;
|
||||||
|
|
||||||
|
try
|
||||||
{
|
{
|
||||||
return true;
|
for( PartP2PFEPower t : PartP2PFEPower.this.getOutputs() )
|
||||||
|
{
|
||||||
|
total += t.getAttachedEnergyStorage().getMaxEnergyStored();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
catch( GridAccessException e )
|
||||||
|
{
|
||||||
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
return super.hasCapability( capability );
|
return total;
|
||||||
}
|
}
|
||||||
|
|
||||||
@Nullable
|
|
||||||
@Override
|
@Override
|
||||||
public <T> T getCapability( @Nonnull Capability<T> capability )
|
public int getEnergyStored()
|
||||||
{
|
{
|
||||||
if( capability == Capabilities.FORGE_ENERGY )
|
int total = 0;
|
||||||
|
|
||||||
|
try
|
||||||
{
|
{
|
||||||
return (T) this;
|
for( PartP2PFEPower t : PartP2PFEPower.this.getOutputs() )
|
||||||
|
{
|
||||||
|
total += t.getAttachedEnergyStorage().getEnergyStored();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
catch( GridAccessException e )
|
||||||
|
{
|
||||||
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
return super.getCapability( capability );
|
return total;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
private class OutputEnergyStorage implements IEnergyStorage
|
||||||
|
{
|
||||||
|
@Override
|
||||||
|
public int extractEnergy( int maxExtract, boolean simulate )
|
||||||
|
{
|
||||||
|
return PartP2PFEPower.this.getAttachedEnergyStorage().extractEnergy( maxExtract, simulate );
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public int receiveEnergy( int maxReceive, boolean simulate )
|
||||||
|
{
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public boolean canExtract()
|
||||||
|
{
|
||||||
|
return PartP2PFEPower.this.getAttachedEnergyStorage().canExtract();
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public boolean canReceive()
|
||||||
|
{
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public int getMaxEnergyStored()
|
||||||
|
{
|
||||||
|
return PartP2PFEPower.this.getAttachedEnergyStorage().getMaxEnergyStored();
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public int getEnergyStored()
|
||||||
|
{
|
||||||
|
return PartP2PFEPower.this.getAttachedEnergyStorage().getEnergyStored();
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
private static class NullEnergyStorage implements IEnergyStorage
|
private static class NullEnergyStorage implements IEnergyStorage
|
||||||
|
@ -285,7 +278,7 @@ public class PartP2PFEPower extends PartP2PTunnel<PartP2PFEPower> implements IEn
|
||||||
@Override
|
@Override
|
||||||
public boolean canReceive()
|
public boolean canReceive()
|
||||||
{
|
{
|
||||||
return true;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -160,6 +160,11 @@ public abstract class PartP2PTunnel<T extends PartP2PTunnel> extends PartBasicSt
|
||||||
@Override
|
@Override
|
||||||
public boolean onPartActivate( final EntityPlayer player, final EnumHand hand, final Vec3d pos )
|
public boolean onPartActivate( final EntityPlayer player, final EnumHand hand, final Vec3d pos )
|
||||||
{
|
{
|
||||||
|
if ( hand == EnumHand.OFF_HAND )
|
||||||
|
{
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
final ItemStack is = player.getHeldItem( hand );
|
final ItemStack is = player.getHeldItem( hand );
|
||||||
|
|
||||||
// UniqueIdentifier id = GameRegistry.findUniqueIdentifierFor( is.getItem() );
|
// UniqueIdentifier id = GameRegistry.findUniqueIdentifierFor( is.getItem() );
|
||||||
|
|
Loading…
Reference in a new issue