fixed items traveling in pipes

This commit is contained in:
SpaceToad 2014-02-10 16:05:05 +01:00
parent f10e728b59
commit f227dc2afc
4 changed files with 34 additions and 3 deletions

View file

@ -31,9 +31,13 @@ public class BuildCraftMod {
channels.get(Side.SERVER).writeOutbound(packet);
}
public void replyToPlayer(EntityPlayer entityplayer, BuildCraftPacket packet) {
channels.get(Side.SERVER).attr(FMLOutboundHandler.FML_MESSAGETARGET).set(OutboundTarget.REPLY);
channels.get(Side.SERVER).writeOutbound(packet);
}
public void sendToServer(BuildCraftPacket packet) {
channels.get(Side.CLIENT).attr(FMLOutboundHandler.FML_MESSAGETARGET).set(OutboundTarget.TOSERVER);
channels.get(Side.CLIENT).writeOutbound(packet);
}
}

View file

@ -1,5 +1,12 @@
package buildcraft.core.network;
import buildcraft.builders.network.PacketLibraryAction;
import buildcraft.transport.network.PacketFluidUpdate;
import buildcraft.transport.network.PacketGateExpansionMap;
import buildcraft.transport.network.PacketPipeTransportItemStack;
import buildcraft.transport.network.PacketPipeTransportItemStackRequest;
import buildcraft.transport.network.PacketPipeTransportTraveler;
import buildcraft.transport.network.PacketPowerUpdate;
import cpw.mods.fml.common.network.FMLIndexedMessageToMessageCodec;
import io.netty.buffer.ByteBuf;
import io.netty.channel.ChannelHandlerContext;
@ -9,6 +16,19 @@ public class BuildCraftChannelHandler extends FMLIndexedMessageToMessageCodec<Bu
public BuildCraftChannelHandler() {
addDiscriminator(0, PacketTileUpdate.class);
addDiscriminator(1, PacketTileState.class);
addDiscriminator(2, PacketCoordinates.class);
addDiscriminator(3, PacketFluidUpdate.class);
addDiscriminator(4, PacketLibraryAction.class);
addDiscriminator(5, PacketNBT.class);
addDiscriminator(6, PacketPowerUpdate.class);
addDiscriminator(7, PacketSlotChange.class);
addDiscriminator(8, PacketGateExpansionMap.class);
addDiscriminator(9, PacketGuiReturn.class);
addDiscriminator(10, PacketGuiWidget.class);
addDiscriminator(11, PacketPipeTransportItemStack.class);
addDiscriminator(12, PacketPipeTransportItemStackRequest.class);
addDiscriminator(13, PacketPipeTransportTraveler.class);
addDiscriminator(14, PacketUpdate.class);
}
@Override

View file

@ -15,6 +15,7 @@ import buildcraft.api.transport.IPipeTile.PipeType;
import buildcraft.core.DefaultProps;
import buildcraft.core.IMachine;
import buildcraft.core.inventory.Transactor;
import buildcraft.core.proxy.CoreProxy;
import buildcraft.core.utils.BCLog;
import buildcraft.core.utils.BlockUtil;
import buildcraft.core.utils.MathUtils;
@ -416,12 +417,14 @@ public class PipeTransportItems extends PipeTransport {
*/
public void handleTravelerPacket(PacketPipeTransportTraveler packet) {
TravelingItem item = TravelingItem.clientCache.get(packet.getTravelingEntityId());
if (item == null) {
item = TravelingItem.make(packet.getTravelingEntityId());
}
if (item.getContainer() != container)
if (item.getContainer() != container) {
items.add(item);
}
if (packet.forceStackRefresh() || item.getItemStack() == null) {
BuildCraftTransport.instance.sendToServer(new PacketPipeTransportItemStackRequest(packet.getTravelingEntityId()));

View file

@ -17,6 +17,10 @@ public class PacketPipeTransportItemStackRequest extends BuildCraftPacket {
public int travelerID;
TravelingItem item;
public PacketPipeTransportItemStackRequest() {
}
public PacketPipeTransportItemStackRequest(int travelerID) {
this.travelerID = travelerID;
}
@ -35,7 +39,7 @@ public class PacketPipeTransportItemStackRequest extends BuildCraftPacket {
public void sendDataToPlayer (EntityPlayer player) {
if (item != null) {
BuildCraftTransport.instance.sendToPlayer(
BuildCraftTransport.instance.replyToPlayer(
player,
new PacketPipeTransportItemStack(travelerID, item
.getItemStack()));