2014-04-06 08:55:24 +02:00
|
|
|
package appeng.tile.powersink;
|
|
|
|
|
|
|
|
import net.minecraft.world.World;
|
|
|
|
import net.minecraftforge.common.util.ForgeDirection;
|
|
|
|
import appeng.api.config.PowerUnits;
|
|
|
|
import appeng.core.AppEng;
|
2014-07-24 00:26:23 +02:00
|
|
|
import appeng.integration.IntegrationType;
|
2014-05-10 04:08:56 +02:00
|
|
|
import appeng.integration.abstraction.IMJ5;
|
2014-04-06 08:55:24 +02:00
|
|
|
import appeng.integration.abstraction.helpers.BaseMJperdition;
|
2014-08-28 09:39:52 +02:00
|
|
|
import appeng.tile.TileEvent;
|
|
|
|
import appeng.tile.events.TileEventType;
|
2014-04-06 08:55:24 +02:00
|
|
|
import appeng.transformer.annotations.integration.Interface;
|
|
|
|
import appeng.transformer.annotations.integration.Method;
|
|
|
|
import appeng.util.Platform;
|
|
|
|
import buildcraft.api.power.IPowerReceptor;
|
|
|
|
import buildcraft.api.power.PowerHandler;
|
|
|
|
import buildcraft.api.power.PowerHandler.PowerReceiver;
|
|
|
|
|
2014-05-10 04:08:56 +02:00
|
|
|
@Interface(iname = "MJ5", iface = "buildcraft.api.power.IPowerReceptor")
|
|
|
|
public abstract class MinecraftJoules5 extends AERootPoweredTile implements IPowerReceptor
|
2014-04-06 08:55:24 +02:00
|
|
|
{
|
|
|
|
|
|
|
|
BaseMJperdition bcPowerWrapper;
|
|
|
|
|
2014-08-28 09:39:52 +02:00
|
|
|
@Method(iname = "MJ5")
|
|
|
|
@TileEvent(TileEventType.TICK)
|
|
|
|
public void Tick_MinecraftJoules5()
|
|
|
|
{
|
|
|
|
if ( bcPowerWrapper != null )
|
|
|
|
bcPowerWrapper.Tick();
|
|
|
|
}
|
|
|
|
|
2014-05-10 04:08:56 +02:00
|
|
|
public MinecraftJoules5() {
|
2014-04-06 08:55:24 +02:00
|
|
|
if ( Platform.isServer() )
|
|
|
|
{
|
|
|
|
try
|
|
|
|
{
|
2014-07-24 00:26:23 +02:00
|
|
|
if ( AppEng.instance.isIntegrationEnabled( IntegrationType.MJ5 ) )
|
2014-04-06 08:55:24 +02:00
|
|
|
{
|
2014-07-24 00:26:23 +02:00
|
|
|
IMJ5 mjIntegration = (IMJ5) AppEng.instance.getIntegration( IntegrationType.MJ5 );
|
2014-04-06 08:55:24 +02:00
|
|
|
if ( mjIntegration != null )
|
|
|
|
{
|
2014-08-28 09:39:52 +02:00
|
|
|
bcPowerWrapper = (BaseMJperdition) mjIntegration.createPerdition( this );
|
2014-04-06 08:55:24 +02:00
|
|
|
if ( bcPowerWrapper != null )
|
|
|
|
bcPowerWrapper.configure( 1, 380, 1.0f / 5.0f, 1000 );
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
catch (Throwable t)
|
|
|
|
{
|
|
|
|
// ignore.. no bc?
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
@Override
|
2014-05-10 04:08:56 +02:00
|
|
|
@Method(iname = "MJ5")
|
2014-04-06 08:55:24 +02:00
|
|
|
final public PowerReceiver getPowerReceiver(ForgeDirection side)
|
|
|
|
{
|
|
|
|
if ( internalCanAcceptPower && getPowerSides().contains( side ) && bcPowerWrapper != null )
|
|
|
|
return bcPowerWrapper.getPowerReceiver();
|
|
|
|
return null;
|
|
|
|
}
|
|
|
|
|
|
|
|
@Override
|
2014-05-10 04:08:56 +02:00
|
|
|
@Method(iname = "MJ5")
|
2014-04-06 08:55:24 +02:00
|
|
|
final public void doWork(PowerHandler workProvider)
|
|
|
|
{
|
2014-09-21 00:55:50 +02:00
|
|
|
float required = (float) getExternalPowerDemand( PowerUnits.MJ, bcPowerWrapper.getPowerReceiver().getEnergyStored() );
|
|
|
|
double failed = injectExternalPower( PowerUnits.MJ, bcPowerWrapper.useEnergy( 0.0f, required, true ) );
|
2014-04-06 08:55:24 +02:00
|
|
|
if ( failed > 0.01 )
|
|
|
|
bcPowerWrapper.addEnergy( (float) failed );
|
|
|
|
}
|
|
|
|
|
|
|
|
@Override
|
2014-05-10 04:08:56 +02:00
|
|
|
@Method(iname = "MJ5")
|
2014-04-06 08:55:24 +02:00
|
|
|
final public World getWorld()
|
|
|
|
{
|
|
|
|
return worldObj;
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|