added initial DestroyMessage packet and tests

This commit is contained in:
FateJH 2018-02-27 20:19:14 -05:00
parent 4b2e3763f1
commit e93c510d22
5 changed files with 166 additions and 9 deletions

View file

@ -332,7 +332,7 @@ object GamePacketOpcode extends Enumeration {
case 0x09 => game.HitMessage.decode
case 0x0a => game.HitHint.decode
case 0x0b => noDecoder(DamageMessage)
case 0x0c => noDecoder(DestroyMessage)
case 0x0c => game.DestroyMessage.decode
case 0x0d => game.ReloadMessage.decode
case 0x0e => game.MountVehicleMsg.decode
case 0x0f => game.DismountVehicleMsg.decode

View file

@ -0,0 +1,26 @@
// Copyright (c) 2017 PSForever
package net.psforever.packet.game
import net.psforever.packet.{GamePacketOpcode, Marshallable, PlanetSideGamePacket}
import net.psforever.types.Vector3
import scodec.Codec
import scodec.codecs._
final case class DestroyMessage(unk1 : PlanetSideGUID,
unk2 : PlanetSideGUID,
unk3 : PlanetSideGUID,
pos : Vector3)
extends PlanetSideGamePacket {
type Packet = DestroyMessage
def opcode = GamePacketOpcode.DestroyMessage
def encode = DestroyMessage.encode(this)
}
object DestroyMessage extends Marshallable[DestroyMessage] {
implicit val codec : Codec[DestroyMessage] = (
("unk1" | PlanetSideGUID.codec) ::
("unk2" | PlanetSideGUID.codec) ::
("unk3" | PlanetSideGUID.codec) ::
("pos" | Vector3.codec_pos)
).as[DestroyMessage]
}

View file

@ -6,6 +6,31 @@ import scodec.Codec
import scodec.codecs._
/**
* na<br>
* Global (GUID=0)<br>
* `83 - max boomers`<br>
* `84 - max he mines`<br>
* `85 - max disruptor mines`<br>
* `86 - max spitfire turrets`<br>
* `87 - max motion sensors`<br>
* `88 - max shadow turrets`<br>
* `89 - max cerebus turrets`<br>
* `90 - max Aegis shield generators`<br>
* `91 - max TRAPs`<br>
* `92 - max OMFTs`<br>
* `93 - max sensor disruptors`<br>
* `94 - boomers`<br>
* `95 - he mines`<br>
* `96 - disruptor mines`<br>
* `97 - spitfire turrets`<br>
* `98 - motion sensors`<br>
* `99 - shadow turrets`<br>
* `100 - cerebus turrets`<br>
* `101 - Aegis shield generators`<br>
* `102 - TRAPSs`<br>
* `103 - OMFTs`<br>
* `104 - sensor disruptors`<br>
* <br>
* Players/General:<br>
* Server to client : <br>
* `0 - health`<br>
@ -91,7 +116,6 @@ import scodec.codecs._
* `106 - Custom Head`<br>
* <br>
* `Vehicles:`<br>
* `0 - Vehicle base health`<br>
* `10 - Driver seat permissions (0 = Locked, 1 = Group, 3 = Empire)`<br>
* `11 - Gunner seat(s) permissions (same)`<br>
* `12 - Passenger seat(s) permissions (same)`<br>

View file

@ -0,0 +1,33 @@
// Copyright (c) 2017 PSForever
package game
import org.specs2.mutable._
import net.psforever.packet._
import net.psforever.packet.game._
import net.psforever.types.Vector3
import scodec.bits._
class DestroyMessageTest extends Specification {
val string = hex"0C 74 09 74 09 00 00 06 35 3C FF D7 26 08"
"DestroyMessage" should {
"decode" in {
PacketCoding.DecodePacket(string).require match {
case DestroyMessage(unk1, unk2, unk3, pos) =>
unk1 mustEqual PlanetSideGUID(2420)
unk2 mustEqual PlanetSideGUID(2420)
unk3 mustEqual PlanetSideGUID(0)
pos mustEqual Vector3(1642.0469f, 4091.6172f, 32.59375f)
case _ =>
ko
}
}
"encode" in {
val msg = DestroyMessage(PlanetSideGUID(2420), PlanetSideGUID(2420), PlanetSideGUID(0), Vector3(1642.0469f, 4091.6172f, 32.59375f))
val pkt = PacketCoding.EncodePacket(msg).require.toByteVector
pkt mustEqual string
}
}
}