aboutsummaryrefslogtreecommitdiff
path: root/azalea-protocol/src/packets/game/clientbound_set_equipment_packet.rs
diff options
context:
space:
mode:
authormat <27899617+mat-1@users.noreply.github.com>2024-11-27 19:31:40 -0600
committerGitHub <noreply@github.com>2024-11-27 19:31:40 -0600
commit08958c2278b15ebeac8a964f392ebb792e479b61 (patch)
tree4ae3664cea38d7fd1a8f1e95ed06fac04ffe519e /azalea-protocol/src/packets/game/clientbound_set_equipment_packet.rs
parent139d77d3c2b0922fba5e9d4fa2bd9819d78bd773 (diff)
downloadazalea-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-xazalea-protocol/src/packets/game/clientbound_set_equipment_packet.rs81
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,
- }
- }
-}