Applied-Energistics-2-tiler.../core/sync/packets/PacketCraftRequest.java

121 lines
3.3 KiB
Java
Raw Normal View History

2014-06-16 07:49:37 +02:00
package appeng.core.sync.packets;
import io.netty.buffer.ByteBuf;
import io.netty.buffer.Unpooled;
import java.io.IOException;
import java.util.concurrent.ExecutorService;
import java.util.concurrent.Executors;
import java.util.concurrent.ThreadFactory;
2014-06-16 07:49:37 +02:00
import net.minecraft.entity.player.EntityPlayer;
import net.minecraft.item.ItemStack;
import net.minecraft.tileentity.TileEntity;
2014-06-16 07:49:37 +02:00
import net.minecraftforge.common.util.ForgeDirection;
import appeng.api.AEApi;
import appeng.api.config.Actionable;
import appeng.api.networking.IGrid;
import appeng.api.networking.IGridHost;
import appeng.api.networking.IGridNode;
import appeng.api.storage.data.IAEItemStack;
import appeng.container.ContainerOpenContext;
2014-06-16 07:49:37 +02:00
import appeng.container.implementations.ContainerCraftAmount;
import appeng.container.implementations.ContainerCraftConfirm;
2014-06-16 07:49:37 +02:00
import appeng.core.AELog;
import appeng.core.sync.AppEngPacket;
import appeng.core.sync.GuiBridge;
2014-06-16 07:49:37 +02:00
import appeng.core.sync.network.INetworkInfo;
import appeng.crafting.CraftingJob;
import appeng.util.Platform;
2014-06-16 07:49:37 +02:00
import appeng.util.item.AEItemStack;
public class PacketCraftRequest extends AppEngPacket
{
final public IAEItemStack slotItem;
2014-06-29 11:06:07 +02:00
final public boolean heldShift;
final public static ExecutorService craftingPool;
static
{
ThreadFactory factory = new ThreadFactory() {
@Override
public Thread newThread(Runnable ar)
{
return new Thread( ar, "AE Crafting Calculator" );
}
};
craftingPool = Executors.newCachedThreadPool( factory );
}
2014-06-16 07:49:37 +02:00
// automatic.
public PacketCraftRequest(ByteBuf stream) throws IOException {
2014-06-29 11:06:07 +02:00
heldShift = stream.readBoolean();
2014-06-16 07:49:37 +02:00
slotItem = AEItemStack.loadItemStackFromPacket( stream );
}
@Override
public void serverPacketData(INetworkInfo manager, AppEngPacket packet, EntityPlayer player)
{
if ( player.openContainer instanceof ContainerCraftAmount )
{
ContainerCraftAmount cca = (ContainerCraftAmount) player.openContainer;
Object targ = cca.getTarget();
if ( targ instanceof IGridHost )
{
IGridHost gh = (IGridHost) targ;
IGridNode gn = gh.getGridNode( ForgeDirection.UNKNOWN );
if ( gn == null )
return;
IGrid g = gn.getGrid();
if ( g == null )
return;
try
{
2014-06-22 09:00:38 +02:00
CraftingJob cj = new CraftingJob( cca.getWorld(), cca, slotItem, Actionable.SIMULATE );
2014-06-16 07:49:37 +02:00
ContainerOpenContext context = cca.openContext;
if ( context != null )
{
TileEntity te = context.w.getTileEntity( context.x, context.y, context.z );
Platform.openGUI( player, te, cca.openContext.side, GuiBridge.GUI_CRAFTING_CONFIRM );
if ( player.openContainer instanceof ContainerCraftConfirm )
{
ContainerCraftConfirm ccc = (ContainerCraftConfirm) player.openContainer;
2014-06-29 11:06:07 +02:00
ccc.autoStart = heldShift;
ccc.job = craftingPool.submit( cj, cj );
cca.detectAndSendChanges();
}
}
2014-06-16 07:49:37 +02:00
}
catch (Throwable e)
{
AELog.error( e );
}
}
}
}
2014-06-29 11:06:07 +02:00
public PacketCraftRequest(ItemStack stack, int parseInt, boolean shift) throws IOException {
2014-06-16 07:49:37 +02:00
this.slotItem = AEApi.instance().storage().createItemStack( stack );
this.slotItem.setStackSize( parseInt );
2014-06-29 11:06:07 +02:00
this.heldShift = shift;
2014-06-16 07:49:37 +02:00
ByteBuf data = Unpooled.buffer();
data.writeInt( getPacketID() );
2014-06-29 11:06:07 +02:00
data.writeBoolean( shift );
2014-06-16 07:49:37 +02:00
slotItem.writeToPacket( data );
configureWrite( data );
}
}