From 09add3e8ac3be54b1e6c068e87d4fb5143c6d785 Mon Sep 17 00:00:00 2001 From: Dream-Master Date: Tue, 21 Jun 2016 18:50:29 +0200 Subject: even with Blood asp experimental branch --- .../gregtech/api/net/GT_Packet_TileEntity.java | 84 ++++++++++++++++++++++ 1 file changed, 84 insertions(+) create mode 100644 src/main/java/gregtech/api/net/GT_Packet_TileEntity.java (limited to 'src/main/java/gregtech/api/net/GT_Packet_TileEntity.java') diff --git a/src/main/java/gregtech/api/net/GT_Packet_TileEntity.java b/src/main/java/gregtech/api/net/GT_Packet_TileEntity.java new file mode 100644 index 0000000000..b916da27b9 --- /dev/null +++ b/src/main/java/gregtech/api/net/GT_Packet_TileEntity.java @@ -0,0 +1,84 @@ +package gregtech.api.net; + +import com.google.common.io.ByteArrayDataInput; +import com.google.common.io.ByteArrayDataOutput; +import com.google.common.io.ByteStreams; +import gregtech.api.metatileentity.BaseMetaPipeEntity; +import gregtech.api.metatileentity.BaseMetaTileEntity; +import net.minecraft.tileentity.TileEntity; +import net.minecraft.world.IBlockAccess; + +public class GT_Packet_TileEntity extends GT_Packet { + private int mX, mZ, mC0, mC1, mC2, mC3, mC4, mC5; + private short mY, mID; + private byte mTexture, mUpdate, mRedstone, mColor; + + public GT_Packet_TileEntity() { + super(true); + } + + public GT_Packet_TileEntity(int aX, short aY, int aZ, short aID, int aC0, int aC1, int aC2, int aC3, int aC4, int aC5, byte aTexture, byte aUpdate, byte aRedstone, byte aColor) { + super(false); + mX = aX; + mY = aY; + mZ = aZ; + mC0 = aC0; + mC1 = aC1; + mC2 = aC2; + mC3 = aC3; + mC4 = aC4; + mC5 = aC5; + mID = aID; + mTexture = aTexture; + mUpdate = aUpdate; + mRedstone = aRedstone; + mColor = aColor; + } + + @Override + public byte[] encode() { + ByteArrayDataOutput tOut = ByteStreams.newDataOutput(40); + + tOut.writeInt(mX); + tOut.writeShort(mY); + tOut.writeInt(mZ); + tOut.writeShort(mID); + + tOut.writeInt(mC0); + tOut.writeInt(mC1); + tOut.writeInt(mC2); + tOut.writeInt(mC3); + tOut.writeInt(mC4); + tOut.writeInt(mC5); + + tOut.writeByte(mTexture); + tOut.writeByte(mUpdate); + tOut.writeByte(mRedstone); + tOut.writeByte(mColor); + + return tOut.toByteArray(); + } + + @Override + public GT_Packet decode(ByteArrayDataInput aData) { + return new GT_Packet_TileEntity(aData.readInt(), aData.readShort(), aData.readInt(), aData.readShort(), aData.readInt(), aData.readInt(), aData.readInt(), aData.readInt(), aData.readInt(), aData.readInt(), aData.readByte(), aData.readByte(), aData.readByte(), aData.readByte()); + } + + @Override + public void process(IBlockAccess aWorld) { + if (aWorld != null) { + TileEntity tTileEntity = aWorld.getTileEntity(mX, mY, mZ); + if (tTileEntity != null) { + if (tTileEntity instanceof BaseMetaTileEntity) + ((BaseMetaTileEntity) tTileEntity).receiveMetaTileEntityData(mID, mC0, mC1, mC2, mC3, mC4, mC5, mTexture, mUpdate, mRedstone, mColor); + else if (tTileEntity instanceof BaseMetaPipeEntity) + ((BaseMetaPipeEntity) tTileEntity).receiveMetaTileEntityData(mID, mC0, mC1, mC2, mC3, mC4, mC5, mTexture, mUpdate, mRedstone, mColor); + } + } + } + + @Override + public byte getPacketID() { + return 0; + } +} \ No newline at end of file -- cgit