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

106 lines
2.8 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.Future;
2014-06-16 07:49:37 +02:00
import net.minecraft.entity.player.EntityPlayer;
import net.minecraft.tileentity.TileEntity;
2014-06-16 07:49:37 +02:00
import net.minecraftforge.common.util.ForgeDirection;
import appeng.api.networking.IGrid;
import appeng.api.networking.IGridHost;
import appeng.api.networking.IGridNode;
import appeng.api.networking.crafting.ICraftingGrid;
import appeng.api.networking.crafting.ICraftingJob;
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.util.Platform;
2014-06-16 07:49:37 +02:00
public class PacketCraftRequest extends AppEngPacket
{
final public long amount;
2014-06-29 11:06:07 +02:00
final public boolean heldShift;
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();
amount = stream.readLong();
2014-06-16 07:49:37 +02:00
}
@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 || cca.whatToMake == null )
2014-06-16 07:49:37 +02:00
return;
Future<ICraftingJob> futureJob = null;
cca.whatToMake.setStackSize( amount );
2014-06-16 07:49:37 +02:00
try
{
ICraftingGrid cg = g.getCache( ICraftingGrid.class );
futureJob = cg.beginCraftingJob( cca.getWorld(), cca.getGrid(), cca.getActionSrc(), cca.whatToMake, null );
2014-06-16 07:49:37 +02:00
ContainerOpenContext context = cca.openContext;
if ( context != null )
{
2014-07-29 04:51:52 +02:00
TileEntity te = context.getTile();
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 = futureJob;
cca.detectAndSendChanges();
}
}
2014-06-16 07:49:37 +02:00
}
catch (Throwable e)
{
if ( futureJob != null )
futureJob.cancel( true );
2014-06-16 07:49:37 +02:00
AELog.error( e );
}
}
}
}
public PacketCraftRequest(int craftAmt, boolean shift) throws IOException {
this.amount = craftAmt;
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 );
data.writeLong( amount );
2014-06-16 07:49:37 +02:00
configureWrite( data );
}
}