Packet: DropItemMessage

* Add DropItemMessage packet

* Add DropItemMessage test

* Add DropItemMessage handler stub
This commit is contained in:
tfarley 2016-07-23 18:40:59 -07:00 committed by pschord
parent 3e980bbe15
commit 47bef6e83b
4 changed files with 43 additions and 1 deletions

View file

@ -384,7 +384,7 @@ object GamePacketOpcode extends Enumeration {
case WeaponFireMessage => noDecoder(opcode)
case AvatarJumpMessage => noDecoder(opcode)
case PickupItemMessage => noDecoder(opcode)
case DropItemMessage => noDecoder(opcode)
case DropItemMessage => game.DropItemMessage.decode
case InventoryStateMessage => noDecoder(opcode)
case ChangeFireStateMessage_Start => game.ChangeFireStateMessage_Start.decode
case ChangeFireStateMessage_Stop => game.ChangeFireStateMessage_Stop.decode

View file

@ -0,0 +1,19 @@
// 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 DropItemMessage(item_guid : PlanetSideGUID)
extends PlanetSideGamePacket {
type Packet = DropItemMessage
def opcode = GamePacketOpcode.DropItemMessage
def encode = DropItemMessage.encode(this)
}
object DropItemMessage extends Marshallable[DropItemMessage] {
implicit val codec : Codec[DropItemMessage] = (
("item_guid" | PlanetSideGUID.codec)
).as[DropItemMessage]
}

View file

@ -285,5 +285,25 @@ class GamePacketTest extends Specification {
pkt mustEqual string
}
}
"DropItemMessage" should {
val string = hex"37 4C00"
"decode" in {
PacketCoding.DecodePacket(string).require match {
case DropItemMessage(item_guid) =>
item_guid mustEqual PlanetSideGUID(76)
case default =>
ko
}
}
"encode" in {
val msg = DropItemMessage(PlanetSideGUID(76))
val pkt = PacketCoding.EncodePacket(msg).require.toByteVector
pkt mustEqual string
}
}
}
}

View file

@ -167,6 +167,9 @@ class WorldSessionActor extends Actor with MDCContextAware {
log.info("Emote: " + msg)
sendResponse(PacketCoding.CreateGamePacket(0, EmoteMsg(avatar_guid, emote_id)))
case msg @ DropItemMessage(item_guid) =>
log.info("DropItem: " + msg)
case default => log.debug(s"Unhandled GamePacket ${pkt}")
}