diff options
Diffstat (limited to 'azalea-protocol/src/packets/game/serverbound_interact_packet.rs')
| -rwxr-xr-x | azalea-protocol/src/packets/game/serverbound_interact_packet.rs | 86 |
1 files changed, 0 insertions, 86 deletions
diff --git a/azalea-protocol/src/packets/game/serverbound_interact_packet.rs b/azalea-protocol/src/packets/game/serverbound_interact_packet.rs deleted file mode 100755 index e393920c..00000000 --- a/azalea-protocol/src/packets/game/serverbound_interact_packet.rs +++ /dev/null @@ -1,86 +0,0 @@ -use std::io::{Cursor, Write}; - -use azalea_buf::{McBuf, McBufReadable, McBufVarReadable, McBufVarWritable, McBufWritable}; -use azalea_core::position::Vec3; -use azalea_protocol_macros::ServerboundGamePacket; - -use crate::packets::BufReadError; - -#[derive(Clone, Debug, McBuf, ServerboundGamePacket)] -pub struct ServerboundInteractPacket { - #[var] - pub entity_id: u32, - pub action: ActionType, - /// Whether the player is sneaking - pub using_secondary_action: bool, -} - -#[derive(Clone, Copy, Debug)] -pub enum ActionType { - Interact { - hand: InteractionHand, - }, - Attack, - InteractAt { - location: Vec3, - hand: InteractionHand, - }, -} - -impl McBufWritable for ActionType { - fn write_into(&self, buf: &mut impl Write) -> Result<(), std::io::Error> { - match self { - ActionType::Interact { hand } => { - 0u32.var_write_into(buf)?; - hand.write_into(buf)?; - } - ActionType::Attack => { - 1u32.var_write_into(buf)?; - } - ActionType::InteractAt { location, hand } => { - 2u32.var_write_into(buf)?; - (location.x as f32).write_into(buf)?; - (location.y as f32).write_into(buf)?; - (location.z as f32).write_into(buf)?; - hand.write_into(buf)?; - } - } - Ok(()) - } -} - -impl McBufReadable for ActionType { - fn read_from(buf: &mut Cursor<&[u8]>) -> Result<Self, BufReadError> { - let action_type = u32::var_read_from(buf)?; - match action_type { - 0 => { - let hand = InteractionHand::read_from(buf)?; - Ok(ActionType::Interact { hand }) - } - 1 => Ok(ActionType::Attack), - 2 => { - let x = f32::read_from(buf)?; - let y = f32::read_from(buf)?; - let z = f32::read_from(buf)?; - let hand = InteractionHand::read_from(buf)?; - Ok(ActionType::InteractAt { - location: Vec3 { - x: f64::from(x), - y: f64::from(y), - z: f64::from(z), - }, - hand, - }) - } - _ => Err(BufReadError::UnexpectedEnumVariant { - id: action_type as i32, - }), - } - } -} - -#[derive(McBuf, Clone, Copy, Debug)] -pub enum InteractionHand { - MainHand = 0, - OffHand = 1, -} |
