use of net.minecraft.inventory.Container in project Engine by VoltzEngine-Project.
the class PacketGui method handleServerSide.
@Override
public void handleServerSide(EntityPlayer player) {
Container container = player.openContainer;
Location location = new Location(player);
if (container instanceof IPacketIDReceiver) {
if (((IPacketIDReceiver) container).shouldReadPacket(player, location, this)) {
try {
IPacketIDReceiver receiver = (IPacketIDReceiver) container;
ByteBuf buf = data().slice();
int id;
try {
id = buf.readInt();
} catch (IndexOutOfBoundsException ex) {
Engine.instance.logger().error(new PacketIDException(location));
return;
}
receiver.read(buf, id, player, this);
} catch (IndexOutOfBoundsException e) {
Engine.instance.logger().error(new PacketTileReadException(location, "Packet was read past it's size."));
Engine.instance.logger().error("Error: ", e);
} catch (NullPointerException e) {
Engine.instance.logger().error(new PacketTileReadException(location, "Null pointer while reading data", e));
Engine.instance.logger().error("Error: ", e);
} catch (Exception e) {
Engine.instance.logger().error(new PacketTileReadException(location, "Failed to read packet", e));
Engine.instance.logger().error("Error: ", e);
}
} else {
Engine.instance.logger().error("Error: " + container + " rejected packet " + this + " due to invalid conditions.");
}
} else if (container instanceof IPacketReceiver) {
if (((IPacketReceiver) container).shouldReadPacket(player, location, this)) {
try {
IPacketReceiver receiver = (IPacketReceiver) container;
receiver.read(data().slice(), player, this);
} catch (IndexOutOfBoundsException e) {
Engine.instance.logger().error(new PacketTileReadException(location, "Packet was read past it's size."));
} catch (Exception e) {
Engine.instance.logger().error(new PacketTileReadException(location, "Failed to read packet", e));
e.printStackTrace();
}
} else {
Engine.instance.logger().error("Error: " + container + " rejected packet " + this + " due to invalid conditions.");
}
} else {
Engine.instance.logger().error(new PacketTileReadException(location, "Unsupported action for " + container));
}
}
Aggregations