use std::io::{Read, Write};
use crate::Guid;
use crate::tbc::{
MovementFlags, MovementInfo, TransportInfo, Vector3d,
};
#[derive(Debug, Clone, PartialEq, PartialOrd, Default)]
pub struct MSG_MOVE_HOVER {
pub player: Guid,
pub info: MovementInfo,
}
impl crate::private::Sealed for MSG_MOVE_HOVER {}
impl MSG_MOVE_HOVER {
fn read_inner(mut r: &mut &[u8], body_size: u32) -> Result<Self, crate::errors::ParseErrorKind> {
if !(30..=91).contains(&body_size) {
return Err(crate::errors::ParseErrorKind::InvalidSize);
}
let player = crate::util::read_packed_guid(&mut r)?;
let info = MovementInfo::read(&mut r)?;
Ok(Self {
player,
info,
})
}
}
impl crate::Message for MSG_MOVE_HOVER {
const OPCODE: u32 = 0x00f7;
#[cfg(feature = "print-testcase")]
fn message_name(&self) -> &'static str {
"MSG_MOVE_HOVER"
}
#[cfg(feature = "print-testcase")]
fn to_test_case_string(&self) -> Option<String> {
panic!("MSG types not supported");
}
fn size_without_header(&self) -> u32 {
self.size() as u32
}
fn write_into_vec(&self, mut w: impl Write) -> Result<(), std::io::Error> {
crate::util::write_packed_guid(&self.player, &mut w)?;
self.info.write_into_vec(&mut w)?;
Ok(())
}
fn read_body<S: crate::private::Sealed>(r: &mut &[u8], body_size: u32) -> Result<Self, crate::errors::ParseError> {
Self::read_inner(r, body_size).map_err(|a| crate::errors::ParseError::new(247, "MSG_MOVE_HOVER", body_size, a))
}
}
#[cfg(feature = "tbc")]
impl crate::tbc::ClientMessage for MSG_MOVE_HOVER {}
#[cfg(feature = "tbc")]
impl crate::tbc::ServerMessage for MSG_MOVE_HOVER {}
impl MSG_MOVE_HOVER {
pub(crate) const fn size(&self) -> usize {
crate::util::packed_guid_size(&self.player) + self.info.size() }
}