| package li.cil.oc.client |
| |
| import li.cil.oc.api.network.Environment |
| import li.cil.oc.common.PacketBuilder |
| import li.cil.oc.common.PacketType |
| import li.cil.oc.common.tileentity._ |
| import net.minecraft.tileentity.TileEntity |
| |
| object PacketSender { |
| def sendComputerStateRequest(t: Case) { |
| val pb = new PacketBuilder(PacketType.ComputerStateRequest) |
| |
| pb.writeTileEntity(t) |
| |
| pb.sendToServer() |
| } |
| |
| def sendPowerStateRequest(t: PowerDistributor) { |
| val pb = new PacketBuilder(PacketType.PowerStateRequest) |
| |
| pb.writeTileEntity(t) |
| |
| pb.sendToServer() |
| } |
| |
| def sendRedstoneStateRequest(t: TileEntity with Redstone) { |
| val pb = new PacketBuilder(PacketType.RedstoneStateRequest) |
| |
| pb.writeTileEntity(t) |
| |
| pb.sendToServer() |
| } |
| |
| def sendRotatableStateRequest(t: TileEntity with Rotatable) { |
| val pb = new PacketBuilder(PacketType.RotatableStateRequest) |
| |
| pb.writeTileEntity(t) |
| |
| pb.sendToServer() |
| } |
| |
| def sendScreenBufferRequest(t: Screen) { |
| val pb = new PacketBuilder(PacketType.ScreenBufferRequest) |
| |
| pb.writeTileEntity(t) |
| |
| pb.sendToServer() |
| } |
| |
| def sendKeyDown[T <: TileEntity with Environment](t: T, char: Char, code: Int) { |
| val pb = new PacketBuilder(PacketType.KeyDown) |
| |
| pb.writeTileEntity(t) |
| pb.writeChar(char) |
| pb.writeInt(code) |
| |
| pb.sendToServer() |
| } |
| |
| def sendKeyUp[T <: TileEntity with Environment](t: T, char: Char, code: Int) { |
| val pb = new PacketBuilder(PacketType.KeyUp) |
| |
| pb.writeTileEntity(t) |
| pb.writeChar(char) |
| pb.writeInt(code) |
| |
| pb.sendToServer() |
| } |
| |
| def sendClipboard[T <: TileEntity with Environment](t: T, value: String) = if (!value.isEmpty) { |
| val pb = new PacketBuilder(PacketType.Clipboard) |
| |
| pb.writeTileEntity(t) |
| pb.writeUTF(value) |
| |
| pb.sendToServer() |
| } |
| } |