mirror of
https://github.com/2revoemag/PSF-BotServer.git
synced 2026-04-29 07:45:26 +00:00
added MountVehicleMsg packet and tests
This commit is contained in:
parent
daa22c572e
commit
dbb640f3b5
4 changed files with 61 additions and 1 deletions
|
|
@ -334,7 +334,7 @@ object GamePacketOpcode extends Enumeration {
|
||||||
case 0x0b => noDecoder(DamageMessage)
|
case 0x0b => noDecoder(DamageMessage)
|
||||||
case 0x0c => noDecoder(DestroyMessage)
|
case 0x0c => noDecoder(DestroyMessage)
|
||||||
case 0x0d => game.ReloadMessage.decode
|
case 0x0d => game.ReloadMessage.decode
|
||||||
case 0x0e => noDecoder(MountVehicleMsg)
|
case 0x0e => game.MountVehicleMsg.decode
|
||||||
case 0x0f => noDecoder(DismountVehicleMsg)
|
case 0x0f => noDecoder(DismountVehicleMsg)
|
||||||
|
|
||||||
// OPCODES 0x10-1f
|
// OPCODES 0x10-1f
|
||||||
|
|
|
||||||
|
|
@ -0,0 +1,35 @@
|
||||||
|
// Copyright (c) 2016 PSForever.net to present
|
||||||
|
package net.psforever.packet.game
|
||||||
|
|
||||||
|
import net.psforever.packet.{GamePacketOpcode, Marshallable, PlanetSideGamePacket}
|
||||||
|
import scodec.Codec
|
||||||
|
import scodec.codecs._
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Alert that the player wishes to board a vehicle into a specific seat.<br>
|
||||||
|
* <br>
|
||||||
|
* The client will only dispatch this packet when it feels confident that the player can get into the specific seat on a vehicle.
|
||||||
|
* It makes its own check whether or not to display that "enter vehicle here" icon on the ground.
|
||||||
|
* Even without that condition, the player is not allowed to do anything until the server responds in affirmation.<br>
|
||||||
|
* <br>
|
||||||
|
* Base turrets and implant terminals count as "vehicles" for the purpose of mounting.
|
||||||
|
* @param player_guid the player
|
||||||
|
* @param vehicle_guid the vehicle
|
||||||
|
* @param seat the vehicle-specific seat index
|
||||||
|
*/
|
||||||
|
final case class MountVehicleMsg(player_guid : PlanetSideGUID,
|
||||||
|
vehicle_guid : PlanetSideGUID,
|
||||||
|
seat : Int)
|
||||||
|
extends PlanetSideGamePacket {
|
||||||
|
type Packet = MountVehicleMsg
|
||||||
|
def opcode = GamePacketOpcode.MountVehicleMsg
|
||||||
|
def encode = MountVehicleMsg.encode(this)
|
||||||
|
}
|
||||||
|
|
||||||
|
object MountVehicleMsg extends Marshallable[MountVehicleMsg] {
|
||||||
|
implicit val codec : Codec[MountVehicleMsg] = (
|
||||||
|
("player_guid" | PlanetSideGUID.codec) ::
|
||||||
|
("vehicle_guid" | PlanetSideGUID.codec) ::
|
||||||
|
("seat" | uint8L)
|
||||||
|
).as[MountVehicleMsg]
|
||||||
|
}
|
||||||
|
|
@ -341,6 +341,28 @@ class GamePacketTest extends Specification {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
"MountVehicleMsg" should {
|
||||||
|
val string = hex"0E E104 6704 06"
|
||||||
|
|
||||||
|
"decode" in {
|
||||||
|
PacketCoding.DecodePacket(string).require match {
|
||||||
|
case MountVehicleMsg(player_guid, vehicle_guid, seat) =>
|
||||||
|
player_guid mustEqual PlanetSideGUID(1249)
|
||||||
|
vehicle_guid mustEqual PlanetSideGUID(1127)
|
||||||
|
seat mustEqual 6
|
||||||
|
case default =>
|
||||||
|
ko
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
"encode" in {
|
||||||
|
val msg = MountVehicleMsg(PlanetSideGUID(1249), PlanetSideGUID(1127), 6)
|
||||||
|
val pkt = PacketCoding.EncodePacket(msg).require.toByteVector
|
||||||
|
|
||||||
|
pkt mustEqual string
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
"ObjectHeldMessage" should {
|
"ObjectHeldMessage" should {
|
||||||
val string = hex"33 4B00 02 00"
|
val string = hex"33 4B00 02 00"
|
||||||
|
|
||||||
|
|
|
||||||
|
|
@ -274,6 +274,9 @@ class WorldSessionActor extends Actor with MDCContextAware {
|
||||||
case msg @ AvatarFirstTimeEventMessage(avatar_guid, object_guid, unk1, event_name) =>
|
case msg @ AvatarFirstTimeEventMessage(avatar_guid, object_guid, unk1, event_name) =>
|
||||||
log.info("AvatarFirstTimeEvent: " + msg)
|
log.info("AvatarFirstTimeEvent: " + msg)
|
||||||
|
|
||||||
|
case msg @ MountVehicleMsg(player_guid, vehicle_guid, unk) =>
|
||||||
|
log.info("MounVehicleMsg: "+msg)
|
||||||
|
|
||||||
case default => log.debug(s"Unhandled GamePacket ${pkt}")
|
case default => log.debug(s"Unhandled GamePacket ${pkt}")
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
||||||
Loading…
Add table
Add a link
Reference in a new issue