Packet: GenericObjectStateMsg (#36)

* Add GenericObjectStateMsg packet

* Add GenericObjectStateMsg test

* Add GenericObjectStateMsg handler stub
This commit is contained in:
tfarley 2016-07-25 19:20:58 -07:00 committed by pschord
parent 5b5bf28c52
commit d496fc1c2e
4 changed files with 48 additions and 1 deletions

View file

@ -352,7 +352,7 @@ object GamePacketOpcode extends Enumeration {
case PingMsg => noDecoder(opcode)
case VehicleStateMessage => noDecoder(opcode)
case FrameVehicleStateMessage => noDecoder(opcode)
case GenericObjectStateMsg => noDecoder(opcode)
case GenericObjectStateMsg => game.GenericObjectStateMsg.decode
// OPCODE 30
case ChildObjectStateMessage => noDecoder(opcode)

View file

@ -0,0 +1,21 @@
// Copyright (c) 2016 PSForever.net to present
package net.psforever.packet.game
import net.psforever.packet.{GamePacketOpcode, Marshallable, PacketHelpers, PlanetSideGamePacket}
import scodec.Codec
import scodec.codecs._
final case class GenericObjectStateMsg(object_guid : PlanetSideGUID,
state : Long)
extends PlanetSideGamePacket {
type Packet = GenericObjectStateMsg
def opcode = GamePacketOpcode.GenericObjectStateMsg
def encode = GenericObjectStateMsg.encode(this)
}
object GenericObjectStateMsg extends Marshallable[GenericObjectStateMsg] {
implicit val codec : Codec[GenericObjectStateMsg] = (
("object_guid" | PlanetSideGUID.codec) ::
("state" | uint32L)
).as[GenericObjectStateMsg]
}

View file

@ -498,5 +498,26 @@ class GamePacketTest extends Specification {
pkt mustEqual string
}
}
"GenericObjectStateMsg" should {
val string = hex"1D 6401 10000000"
"decode" in {
PacketCoding.DecodePacket(string).require match {
case GenericObjectStateMsg(object_guid, state) =>
object_guid mustEqual PlanetSideGUID(356)
state mustEqual 16
case default =>
ko
}
}
"encode" in {
val msg = GenericObjectStateMsg(PlanetSideGUID(356), 16)
val pkt = PacketCoding.EncodePacket(msg).require.toByteVector
pkt mustEqual string
}
}
}
}