Packet: ReloadMessage

* Add ReloadMessage packet

* Add ReloadMessage test

* Add ReloadMessage handler stub
This commit is contained in:
tfarley 2016-07-23 21:58:38 -07:00 committed by pschord
parent 47bef6e83b
commit 60e7a76de5
4 changed files with 50 additions and 1 deletions

View file

@ -334,7 +334,7 @@ object GamePacketOpcode extends Enumeration {
case HitHint => noDecoder(opcode)
case DamageMessage => noDecoder(opcode)
case DestroyMessage => noDecoder(opcode)
case ReloadMessage => noDecoder(opcode)
case ReloadMessage => game.ReloadMessage.decode
case MountVehicleMsg => noDecoder(opcode)
case DismountVehicleMsg => noDecoder(opcode)
case UseItemMessage => noDecoder(opcode)

View file

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

View file

@ -305,5 +305,27 @@ class GamePacketTest extends Specification {
pkt mustEqual string
}
}
"ReloadMessage" should {
val string = hex"0D 4C00 7B000000 FFFFFFFF"
"decode" in {
PacketCoding.DecodePacket(string).require match {
case ReloadMessage(item_guid, ammo_clip, unk1) =>
item_guid mustEqual PlanetSideGUID(76)
ammo_clip mustEqual 123
unk1 mustEqual -1
case default =>
ko
}
}
"encode" in {
val msg = ReloadMessage(PlanetSideGUID(76), 123, -1)
val pkt = PacketCoding.EncodePacket(msg).require.toByteVector
pkt mustEqual string
}
}
}
}

View file

@ -170,6 +170,10 @@ class WorldSessionActor extends Actor with MDCContextAware {
case msg @ DropItemMessage(item_guid) =>
log.info("DropItem: " + msg)
case msg @ ReloadMessage(item_guid, ammo_clip, unk1) =>
log.info("Reload: " + msg)
sendResponse(PacketCoding.CreateGamePacket(0, ReloadMessage(item_guid, 123, unk1)))
case default => log.debug(s"Unhandled GamePacket ${pkt}")
}