diff options
| author | mat <27899617+mat-1@users.noreply.github.com> | 2024-11-27 19:31:40 -0600 |
|---|---|---|
| committer | GitHub <noreply@github.com> | 2024-11-27 19:31:40 -0600 |
| commit | 08958c2278b15ebeac8a964f392ebb792e479b61 (patch) | |
| tree | 4ae3664cea38d7fd1a8f1e95ed06fac04ffe519e /azalea-protocol/src/packets/game/clientbound_set_equipment_packet.rs | |
| parent | 139d77d3c2b0922fba5e9d4fa2bd9819d78bd773 (diff) | |
| download | azalea-drasl-08958c2278b15ebeac8a964f392ebb792e479b61.tar.xz | |
Refactor azalea-protocol (#190)
* start updating to 1.21.4
* fix block codegen and stop using block data from burger
* rename packet related modules and structs to be simpler
* ItemSlot -> ItemStack for more consistency with mojmap
* .get() -> .into_packet()
* simplify declare_state_packets by removing packet ids
* rename read_from and write_into to azalea_read and azalea_write
* rename McBufReadable and McBufWritable to AzaleaRead and AzaleaWrite
* McBuf -> AzBuf
* remove most uses of into_variant
* update codegen and use resourcelocation names for packets
* implement #[limit(i)] attribute for AzBuf derive macro
* fixes for 1.21.4
* fix examples
* update some physics code and fix ChatType
* remove unused imports in codegen
* re-add some things to migrate.py and update +mc version numbers automatically
* downgrade to 1.21.3 lol
Diffstat (limited to 'azalea-protocol/src/packets/game/clientbound_set_equipment_packet.rs')
| -rwxr-xr-x | azalea-protocol/src/packets/game/clientbound_set_equipment_packet.rs | 81 |
1 files changed, 0 insertions, 81 deletions
diff --git a/azalea-protocol/src/packets/game/clientbound_set_equipment_packet.rs b/azalea-protocol/src/packets/game/clientbound_set_equipment_packet.rs deleted file mode 100755 index 165d05db..00000000 --- a/azalea-protocol/src/packets/game/clientbound_set_equipment_packet.rs +++ /dev/null @@ -1,81 +0,0 @@ -use std::io::Cursor; - -use azalea_buf::{BufReadError, McBuf}; -use azalea_buf::{McBufReadable, McBufWritable}; -use azalea_inventory::ItemSlot; -use azalea_protocol_macros::ClientboundGamePacket; - -#[derive(Clone, Debug, McBuf, ClientboundGamePacket)] -pub struct ClientboundSetEquipmentPacket { - #[var] - pub entity_id: u32, - pub slots: EquipmentSlots, -} - -#[derive(Clone, Debug)] -pub struct EquipmentSlots { - pub slots: Vec<(EquipmentSlot, ItemSlot)>, -} - -impl McBufReadable for EquipmentSlots { - fn read_from(buf: &mut Cursor<&[u8]>) -> Result<Self, BufReadError> { - let mut slots = vec![]; - - loop { - let equipment_byte = u8::read_from(buf)?; - let equipment_slot = - EquipmentSlot::from_byte(equipment_byte & 127).ok_or_else(|| { - BufReadError::UnexpectedEnumVariant { - id: equipment_byte.into(), - } - })?; - let item = ItemSlot::read_from(buf)?; - slots.push((equipment_slot, item)); - if equipment_byte & 128 == 0 { - break; - }; - } - - Ok(EquipmentSlots { slots }) - } -} -impl McBufWritable for EquipmentSlots { - fn write_into(&self, buf: &mut impl std::io::Write) -> Result<(), std::io::Error> { - for i in 0..self.slots.len() { - let (equipment_slot, item) = &self.slots[i]; - let mut equipment_byte = *equipment_slot as u8; - if i != self.slots.len() - 1 { - equipment_byte |= 128; - } - equipment_byte.write_into(buf)?; - item.write_into(buf)?; - } - - Ok(()) - } -} - -#[derive(Clone, Debug, Copy, McBuf)] -pub enum EquipmentSlot { - MainHand = 0, - OffHand = 1, - Feet = 2, - Legs = 3, - Chest = 4, - Head = 5, -} - -impl EquipmentSlot { - #[must_use] - pub fn from_byte(byte: u8) -> Option<Self> { - match byte { - 0 => Some(EquipmentSlot::MainHand), - 1 => Some(EquipmentSlot::OffHand), - 2 => Some(EquipmentSlot::Feet), - 3 => Some(EquipmentSlot::Legs), - 4 => Some(EquipmentSlot::Chest), - 5 => Some(EquipmentSlot::Head), - _ => None, - } - } -} |
