Applied-Energistics-2-tiler.../tile/misc/TileInscriber.java

401 lines
9.9 KiB
Java
Raw Normal View History

package appeng.tile.misc;
2014-02-09 02:34:52 +01:00
import io.netty.buffer.ByteBuf;
import java.io.IOException;
import java.util.EnumSet;
import net.minecraft.inventory.IInventory;
import net.minecraft.item.ItemStack;
import net.minecraft.nbt.NBTTagCompound;
2014-02-09 02:34:52 +01:00
import net.minecraftforge.common.util.ForgeDirection;
import appeng.api.AEApi;
2014-03-12 04:26:50 +01:00
import appeng.api.config.Actionable;
import appeng.api.config.PowerMultiplier;
import appeng.api.networking.IGridNode;
2014-03-12 04:26:50 +01:00
import appeng.api.networking.energy.IEnergyGrid;
import appeng.api.networking.energy.IEnergySource;
import appeng.api.networking.ticking.IGridTickable;
import appeng.api.networking.ticking.TickRateModulation;
import appeng.api.networking.ticking.TickingRequest;
import appeng.api.util.AECableType;
2014-03-17 20:59:50 +01:00
import appeng.core.settings.TickRates;
import appeng.me.GridAccessException;
import appeng.recipes.handlers.Inscribe;
import appeng.recipes.handlers.Inscribe.InscriberRecipe;
2014-08-28 09:39:52 +02:00
import appeng.tile.TileEvent;
import appeng.tile.events.TileEventType;
import appeng.tile.grid.AENetworkPowerTile;
import appeng.tile.inventory.AppEngInternalInventory;
import appeng.tile.inventory.InvOperation;
2014-03-12 04:26:50 +01:00
import appeng.util.InventoryAdaptor;
import appeng.util.Platform;
2014-03-12 04:26:50 +01:00
import appeng.util.inv.WrapperInventoryRange;
import appeng.util.item.AEItemStack;
public class TileInscriber extends AENetworkPowerTile implements IGridTickable
{
final int top[] = new int[] { 0 };
final int bottom[] = new int[] { 1 };
final int sides[] = new int[] { 2, 3 };
AppEngInternalInventory inv = new AppEngInternalInventory( this, 4 );
2014-09-21 01:06:57 +02:00
public final int maxProcessingTime = 100;
public int processingTime = 0;
2014-09-21 01:36:14 +02:00
// cycles from 0 - 16, at 8 it preforms the action, at 16 it re-enables the normal routine.
public boolean smash;
public int finalStep;
public long clientStart;
@Override
public AECableType getCableConnectionType(ForgeDirection dir)
{
return AECableType.COVERED;
}
2014-08-28 09:39:52 +02:00
@TileEvent(TileEventType.WORLD_NBT_WRITE)
public void writeToNBT_TileInscriber(NBTTagCompound data)
{
2014-08-28 09:39:52 +02:00
inv.writeToNBT( data, "inscriberInv" );
}
2014-08-28 09:39:52 +02:00
@TileEvent(TileEventType.WORLD_NBT_READ)
public void readFromNBT_TileInscriber(NBTTagCompound data)
{
inv.readFromNBT( data, "inscriberInv" );
}
2014-08-28 09:39:52 +02:00
@TileEvent(TileEventType.NETWORK_READ)
public boolean readFromStream_TileInscriber(ByteBuf data) throws IOException
{
int slot = data.readByte();
boolean oldSmash = smash;
boolean newSmash = (slot & 64) == 64;
2014-08-28 09:39:52 +02:00
if ( oldSmash != newSmash && newSmash )
{
2014-08-28 09:39:52 +02:00
smash = true;
clientStart = System.currentTimeMillis();
}
2014-08-28 09:39:52 +02:00
for (int num = 0; num < inv.getSizeInventory(); num++)
{
2014-08-28 09:39:52 +02:00
if ( (slot & (1 << num)) > 0 )
inv.setInventorySlotContents( num, AEItemStack.loadItemStackFromPacket( data ).getItemStack() );
else
inv.setInventorySlotContents( num, null );
}
2014-08-28 09:39:52 +02:00
return false;
}
2014-08-28 09:39:52 +02:00
@TileEvent(TileEventType.NETWORK_WRITE)
public void writeToStream_TileInscriber(ByteBuf data) throws IOException
{
int slot = smash ? 64 : 0;
2014-08-28 09:39:52 +02:00
for (int num = 0; num < inv.getSizeInventory(); num++)
{
if ( inv.getStackInSlot( num ) != null )
slot = slot | (1 << num);
}
2014-08-28 09:39:52 +02:00
data.writeByte( slot );
for (int num = 0; num < inv.getSizeInventory(); num++)
{
2014-08-28 09:39:52 +02:00
if ( (slot & (1 << num)) > 0 )
{
2014-08-28 09:39:52 +02:00
AEItemStack st = AEItemStack.create( inv.getStackInSlot( num ) );
st.writeToPacket( data );
}
}
2014-08-28 09:39:52 +02:00
}
@Override
public boolean requiresTESR()
{
return true;
}
public TileInscriber() {
gridProxy.setValidSides( EnumSet.noneOf( ForgeDirection.class ) );
internalMaxPower = 1500;
gridProxy.setIdlePowerUsage( 0 );
}
@Override
public void setOrientation(ForgeDirection inForward, ForgeDirection inUp)
{
super.setOrientation( inForward, inUp );
gridProxy.setValidSides( EnumSet.complementOf( EnumSet.of( getForward() ) ) );
setPowerSides( EnumSet.complementOf( EnumSet.of( getForward() ) ) );
}
@Override
public IInventory getInternalInventory()
{
return inv;
}
@Override
public int[] getAccessibleSlotsBySide(ForgeDirection d)
{
if ( d == ForgeDirection.UP )
return top;
if ( d == ForgeDirection.DOWN )
return bottom;
return sides;
}
@Override
public int getInventoryStackLimit()
{
return 1;
}
@Override
public boolean isItemValidForSlot(int i, ItemStack itemstack)
{
if ( smash )
return false;
if ( i == 0 || i == 1 )
{
if ( AEApi.instance().materials().materialNamePress.sameAsStack( itemstack ) )
return true;
for (ItemStack s : Inscribe.plates)
if ( Platform.isSameItemPrecise( s, itemstack ) )
return true;
}
if ( i == 2 )
{
return true;
// for (ItemStack s : Inscribe.inputs)
// if ( Platform.isSameItemPrecise( s, itemstack ) )
// return true;
}
return false;
}
@Override
public boolean canExtractItem(int i, ItemStack itemstack, int j)
{
if ( smash )
return false;
return i == 0 || i == 1 || i == 3;
}
@Override
public void onChangeInventory(IInventory inv, int slot, InvOperation mc, ItemStack removed, ItemStack added)
{
try
{
2014-03-12 04:26:50 +01:00
if ( mc != InvOperation.markDirty )
{
if ( slot != 3 )
processingTime = 0;
if ( !smash )
markForUpdate();
2014-03-12 04:26:50 +01:00
gridProxy.getTick().wakeDevice( gridProxy.getNode() );
}
}
catch (GridAccessException e)
{
// :P
}
}
public InscriberRecipe getTask()
{
ItemStack PlateA = getStackInSlot( 0 );
ItemStack PlateB = getStackInSlot( 1 );
ItemStack renamedItem = getStackInSlot( 2 );
if ( PlateA != null && PlateA.stackSize > 1 )
return null;
if ( PlateB != null && PlateB.stackSize > 1 )
return null;
if ( renamedItem != null && renamedItem.stackSize > 1 )
return null;
boolean isNameA = AEApi.instance().materials().materialNamePress.sameAsStack( PlateA );
boolean isNameB = AEApi.instance().materials().materialNamePress.sameAsStack( PlateB );
if ( (isNameA || isNameB) && (isNameA || PlateA == null) && (isNameB || PlateB == null) )
{
if ( renamedItem != null )
{
String name = "";
if ( PlateA != null )
{
NBTTagCompound tag = Platform.openNbtData( PlateA );
name += tag.getString( "InscribeName" );
}
if ( PlateB != null )
{
NBTTagCompound tag = Platform.openNbtData( PlateB );
if ( name.length() > 0 )
name += " ";
name += tag.getString( "InscribeName" );
}
ItemStack startingItem = renamedItem.copy();
renamedItem = renamedItem.copy();
NBTTagCompound tag = Platform.openNbtData( renamedItem );
NBTTagCompound display = tag.getCompoundTag( "display" );
tag.setTag( "display", display );
if ( name.length() > 0 )
display.setString( "Name", name );
else
display.removeTag( "Name" );
return new InscriberRecipe( new ItemStack[] { startingItem }, PlateA, PlateB, renamedItem, false );
}
}
for (InscriberRecipe i : Inscribe.recipes)
{
boolean matchA = (PlateA == null && i.plateA == null) || (Platform.isSameItemPrecise( PlateA, i.plateA )) && // and...
(PlateB == null && i.plateB == null) | (Platform.isSameItemPrecise( PlateB, i.plateB ));
boolean matchB = (PlateB == null && i.plateA == null) || (Platform.isSameItemPrecise( PlateB, i.plateA )) && // and...
(PlateA == null && i.plateB == null) | (Platform.isSameItemPrecise( PlateA, i.plateB ));
if ( matchA || matchB )
{
2014-09-21 01:35:50 +02:00
for (ItemStack option : i.imprintable)
{
2014-09-21 01:35:50 +02:00
if ( Platform.isSameItemPrecise( option, getStackInSlot( 2 ) ) )
2014-03-12 04:26:50 +01:00
return i;
}
}
}
return null;
}
private boolean hasWork()
{
if ( getTask() != null )
return true;
processingTime = 0;
return false || smash;
}
@Override
public TickingRequest getTickingRequest(IGridNode node)
{
2014-03-17 20:59:50 +01:00
return new TickingRequest( TickRates.Inscriber.min, TickRates.Inscriber.max, !hasWork(), false );
}
@Override
public TickRateModulation tickingRequest(IGridNode node, int TicksSinceLastCall)
{
if ( smash )
2014-03-12 04:26:50 +01:00
{
finalStep++;
if ( finalStep == 8 )
{
InscriberRecipe out = getTask();
if ( out != null )
{
ItemStack is = out.output.copy();
InventoryAdaptor ad = InventoryAdaptor.getAdaptor( new WrapperInventoryRange( inv, 3, 1, true ), ForgeDirection.UNKNOWN );
2014-03-12 04:26:50 +01:00
if ( ad.addItems( is ) == null )
{
processingTime = 0;
if ( out.usePlates )
{
setInventorySlotContents( 0, null );
setInventorySlotContents( 1, null );
}
setInventorySlotContents( 2, null );
}
}
2014-03-12 04:26:50 +01:00
markDirty();
2014-03-12 04:26:50 +01:00
}
else if ( finalStep == 16 )
{
finalStep = 0;
smash = false;
markForUpdate();
2014-03-12 04:26:50 +01:00
}
}
else
{
IEnergyGrid eg;
try
{
eg = gridProxy.getEnergy();
IEnergySource src = this;
double powerReq = extractAEPower( 10, Actionable.SIMULATE, PowerMultiplier.CONFIG );
2014-08-13 21:57:25 +02:00
if ( powerReq <= 9.99 )
{
src = eg;
powerReq = eg.extractAEPower( 10, Actionable.SIMULATE, PowerMultiplier.CONFIG );
}
if ( powerReq > 9.99 )
{
src.extractAEPower( 10, Actionable.MODULATE, PowerMultiplier.CONFIG );
if ( processingTime == 0 )
processingTime++;
else
processingTime += TicksSinceLastCall;
}
}
catch (GridAccessException e)
{
// :P
}
2014-09-21 01:06:57 +02:00
if ( processingTime > maxProcessingTime )
{
2014-09-21 01:06:57 +02:00
processingTime = maxProcessingTime;
InscriberRecipe out = getTask();
if ( out != null )
2014-03-12 04:26:50 +01:00
{
ItemStack is = out.output.copy();
InventoryAdaptor ad = InventoryAdaptor.getAdaptor( new WrapperInventoryRange( inv, 3, 1, true ), ForgeDirection.UNKNOWN );
if ( ad.simulateAdd( is ) == null )
2014-03-12 04:26:50 +01:00
{
smash = true;
finalStep = 0;
markForUpdate();
2014-03-12 04:26:50 +01:00
}
}
}
}
return hasWork() ? TickRateModulation.URGENT : TickRateModulation.SLEEP;
}
}