From 9f5e5c092be9167e4d5222fdee4a1d2c419e5052 Mon Sep 17 00:00:00 2001 From: EightFactorial Date: Tue, 6 Dec 2022 18:48:48 -0800 Subject: Complete ClientboundCommand{Suggestion}sPacket, Serde support for NBT Tags (#49) * Serializing ClientboundStatusResponsePacket Enable serialization of ClientboundStatusResponsePacket * Update clientbound_status_response_packet.rs Add options previewsChat and enforcesSecureChat * Serialize Style and TextColor * Serialize BaseComponent * Serialize TextComponent * Fix Style * Serialize Component * Fix multiple formats per message, fix reset tag * Fix Style, again * Use FlatMapSerializer * Forgot italics * Count struct fields, reorganize logic * Serialize TranslatableComponent * Rewrite TextComponent Serializer * Fix using TextColor::Parse * Code Cleanup * Add default attribute, just in case * Clippy * use serde derive feature + preferred formatting choices * McBufWritable for BrigadierNodeStub * Thanks Clippy... * Implement suggestions in azalea-brigadier * Serde support for NBT Tags * Serde options * Forgot Options * Oops, that's McBufWritable for BrigadierParser * Fix McBufWritable for SlotData * Complete ClientboundUpdateRecipesPacket * fix some issues * better impl McBufReadable for Suggestions Co-authored-by: BuildTools Co-authored-by: mat --- azalea-core/src/slot.rs | 23 +++++++++++------------ 1 file changed, 11 insertions(+), 12 deletions(-) (limited to 'azalea-core/src') diff --git a/azalea-core/src/slot.rs b/azalea-core/src/slot.rs index f1cd4f0b..4406e08d 100755 --- a/azalea-core/src/slot.rs +++ b/azalea-core/src/slot.rs @@ -1,6 +1,7 @@ // TODO: have an azalea-inventory or azalea-container crate and put this there use azalea_buf::{BufReadError, McBuf, McBufReadable, McBufWritable}; +use azalea_nbt::Tag; use std::io::{Cursor, Write}; #[derive(Debug, Clone, Default)] @@ -13,29 +14,27 @@ pub enum Slot { #[derive(Debug, Clone, McBuf)] pub struct SlotData { #[var] - pub id: i32, + pub id: u32, pub count: u8, - pub nbt: azalea_nbt::Tag, + pub nbt: Tag, } impl McBufReadable for Slot { fn read_from(buf: &mut Cursor<&[u8]>) -> Result { - let present = bool::read_from(buf)?; - if !present { - return Ok(Slot::Empty); - } - let slot = SlotData::read_from(buf)?; - Ok(Slot::Present(slot)) + let slot = Option::::read_from(buf)?; + Ok(slot.map_or(Slot::Empty, Slot::Present)) } } impl McBufWritable for Slot { fn write_into(&self, buf: &mut impl Write) -> Result<(), std::io::Error> { match self { - Slot::Empty => 0u8.write_into(buf)?, - Slot::Present(i) => i.write_into(buf)?, - } - + Slot::Empty => false.write_into(buf)?, + Slot::Present(i) => { + true.write_into(buf)?; + i.write_into(buf)?; + } + }; Ok(()) } } -- cgit v1.2.3