From 9223c8bf5419d44a1349b350e166a6b9970f1b3e Mon Sep 17 00:00:00 2001 From: Edvin Bryntesson Date: Mon, 19 Aug 2024 23:35:45 +0200 Subject: [PATCH 01/15] Add missing slots in inventory --- pumpkin-inventory/src/player.rs | 20 ++++++++++++++++++-- 1 file changed, 18 insertions(+), 2 deletions(-) diff --git a/pumpkin-inventory/src/player.rs b/pumpkin-inventory/src/player.rs index 08a464e8..b53be762 100644 --- a/pumpkin-inventory/src/player.rs +++ b/pumpkin-inventory/src/player.rs @@ -2,13 +2,27 @@ use pumpkin_world::item::Item; pub struct PlayerInventory { // Main Inventory + Hotbar + crafting: [Option; 4], + crafting_output: Option, items: [Option; 36], armor: [Option; 4], offhand: Option, - // current selected slot in hortbar - selected: i16, + // current selected slot in hotbar + selected: usize, } +pub struct Hotbar<'a>(&'a mut [Option;9]); + +impl Hotbar<'_> { + fn get_mut(&mut self, index: usize) -> &mut Option { + &mut self.0[index] + } +} + +pub struct Armor<'a>(&'a mut [Option; 4]); + + + impl Default for PlayerInventory { fn default() -> Self { Self::new() @@ -18,6 +32,8 @@ impl Default for PlayerInventory { impl PlayerInventory { pub fn new() -> Self { Self { + crafting: [None; 4], + crafting_output: None, items: [None; 36], armor: [None; 4], offhand: None, From 9e14952046d1d02194f6c2e1b1104f9309a87854 Mon Sep 17 00:00:00 2001 From: Edvin Bryntesson Date: Mon, 19 Aug 2024 23:37:35 +0200 Subject: [PATCH 02/15] fix typo --- pumpkin-world/src/item/item_registry.rs | 4 ++-- pumpkin-world/src/item/mod.rs | 4 ++-- 2 files changed, 4 insertions(+), 4 deletions(-) diff --git a/pumpkin-world/src/item/item_registry.rs b/pumpkin-world/src/item/item_registry.rs index 669501a9..278d793f 100644 --- a/pumpkin-world/src/item/item_registry.rs +++ b/pumpkin-world/src/item/item_registry.rs @@ -4,7 +4,7 @@ use lazy_static::lazy_static; use crate::global_registry::{self, ITEM_REGISTRY}; -use super::Raritiy; +use super::Rarity; const ITEMS_JSON: &str = include_str!("../../assets/items.json"); @@ -17,7 +17,7 @@ pub struct ItemComponents { #[serde(rename = "minecraft:max_stack_size")] max_stack_size: u32, #[serde(rename = "minecraft:rarity")] - rarity: Raritiy, + rarity: Rarity, #[serde(rename = "minecraft:repair_cost")] repair_cost: u32, } diff --git a/pumpkin-world/src/item/mod.rs b/pumpkin-world/src/item/mod.rs index ef9ec114..79fe1f33 100644 --- a/pumpkin-world/src/item/mod.rs +++ b/pumpkin-world/src/item/mod.rs @@ -2,8 +2,8 @@ mod item_registry; #[derive(serde::Deserialize, Debug, Clone, PartialEq, Eq)] #[serde(rename_all = "lowercase")] -/// Item Raritiy -pub enum Raritiy { +/// Item Rarity +pub enum Rarity { Common, UnCommon, Rare, From 918364f5360ce9696f99e051c36c8cf20f87b260 Mon Sep 17 00:00:00 2001 From: Edvin Bryntesson Date: Mon, 19 Aug 2024 23:38:05 +0200 Subject: [PATCH 03/15] add item id and count to item struct --- pumpkin-world/src/item/mod.rs | 7 ++++++- 1 file changed, 6 insertions(+), 1 deletion(-) diff --git a/pumpkin-world/src/item/mod.rs b/pumpkin-world/src/item/mod.rs index 79fe1f33..3cd9c839 100644 --- a/pumpkin-world/src/item/mod.rs +++ b/pumpkin-world/src/item/mod.rs @@ -11,4 +11,9 @@ pub enum Rarity { } #[derive(Clone, Copy)] -pub struct Item {} +pub struct Item { + item_count: u32, + // This ID is the numerical protocol ID, not the usual minecraft::block ID. + item_id: u32, + // TODO: Add Item Components +} From 658cb297f10bbb213bf0db0ce3035a16c98a6bb8 Mon Sep 17 00:00:00 2001 From: Edvin Bryntesson Date: Mon, 19 Aug 2024 23:39:39 +0200 Subject: [PATCH 04/15] add item category checks this is for if a specific slot can only accept a specific category of items, like you can only put helmets in the helmet armor slot --- .../src/item/item_category_checks.rs | 75 +++++++++++++++++++ pumpkin-world/src/item/mod.rs | 1 + 2 files changed, 76 insertions(+) create mode 100644 pumpkin-world/src/item/item_category_checks.rs diff --git a/pumpkin-world/src/item/item_category_checks.rs b/pumpkin-world/src/item/item_category_checks.rs new file mode 100644 index 00000000..dfd032e3 --- /dev/null +++ b/pumpkin-world/src/item/item_category_checks.rs @@ -0,0 +1,75 @@ +use crate::item::Item; + +impl Item { + pub fn is_helmet(&self) -> bool { + [ + // Leather + 856, + // Netherite + 876, + // Turtle helmet + 794, + // Chainmail + 860, + // Diamond + 868, + // Gold + 872, + // Iron + 864 + ].contains(&self.item_id) + } + + pub fn is_chestplate(&self) -> bool { + [ + // Leather + 857, + // Netherite + 877, + // Chainmail + 861, + // Diamond + 869, + // Gold + 873, + // Iron + 865, + // Elytra + 773, + ].contains(&self.item_id) + } + + pub fn is_leggings(&self) -> bool { + [ + // Leather + 858, + // Netherite + 878, + // Chainmail + 862, + // Diamond + 870, + // Gold + 874, + // Iron + 866 + ].contains(&self.item_id) + } + + pub fn is_boots(&self) -> bool { + [ + // Leather + 859, + // Netherite + 879, + // Chainmail + 863, + // Diamond + 871, + // Gold + 875, + // Iron + 867 + ].contains(&self.item_id) + } +} \ No newline at end of file diff --git a/pumpkin-world/src/item/mod.rs b/pumpkin-world/src/item/mod.rs index 3cd9c839..54c786fe 100644 --- a/pumpkin-world/src/item/mod.rs +++ b/pumpkin-world/src/item/mod.rs @@ -1,4 +1,5 @@ mod item_registry; +mod item_category_checks; #[derive(serde::Deserialize, Debug, Clone, PartialEq, Eq)] #[serde(rename_all = "lowercase")] From 3d8c9cc62e6ad6ef4c935a60c39628dd1329e6e4 Mon Sep 17 00:00:00 2001 From: Edvin Bryntesson Date: Mon, 19 Aug 2024 23:40:43 +0200 Subject: [PATCH 05/15] use usize for selected slot --- pumpkin-inventory/src/player.rs | 2 +- pumpkin/src/client/player_packet.rs | 2 +- 2 files changed, 2 insertions(+), 2 deletions(-) diff --git a/pumpkin-inventory/src/player.rs b/pumpkin-inventory/src/player.rs index b53be762..5cca279c 100644 --- a/pumpkin-inventory/src/player.rs +++ b/pumpkin-inventory/src/player.rs @@ -44,7 +44,7 @@ impl PlayerInventory { pub fn set_slot(slot: u32, item: Item) {} - pub fn set_selected(&mut self, slot: i16) { + pub fn set_selected(&mut self, slot: usize) { assert!((0..9).contains(&slot)); self.selected = slot; } diff --git a/pumpkin/src/client/player_packet.rs b/pumpkin/src/client/player_packet.rs index 297a30c5..0904e1b9 100644 --- a/pumpkin/src/client/player_packet.rs +++ b/pumpkin/src/client/player_packet.rs @@ -331,7 +331,7 @@ impl Client { self.kick("Invalid held slot") } let player = self.player.as_mut().unwrap(); - player.inventory.set_selected(slot); + player.inventory.set_selected(slot as usize); } pub fn handle_set_creative_slot(&mut self, _server: &mut Server, packet: SSetCreativeSlot) { From 2cf844536ad4a5267e5f4c64e94ab284e2d2ea82 Mon Sep 17 00:00:00 2001 From: Edvin Bryntesson Date: Mon, 19 Aug 2024 23:41:44 +0200 Subject: [PATCH 06/15] add basic logic for set slot in player inventory --- pumpkin-inventory/src/player.rs | 59 ++++++++++++++++++++++++++++++++- 1 file changed, 58 insertions(+), 1 deletion(-) diff --git a/pumpkin-inventory/src/player.rs b/pumpkin-inventory/src/player.rs index 5cca279c..5b8aa2e4 100644 --- a/pumpkin-inventory/src/player.rs +++ b/pumpkin-inventory/src/player.rs @@ -42,7 +42,64 @@ impl PlayerInventory { } } - pub fn set_slot(slot: u32, item: Item) {} + /// Set the contents of an item in a slot + /// + /// ## Slot + /// The slot according to https://wiki.vg/Inventory#Player_Inventory + /// + /// ## Item + /// The optional item to place in the slot + /// + /// ## Item allowed override + /// An override, which when enabled, makes it so that invalid items, can be placed in slots they normally can't. + /// Useful functionality for plugins in the future. + pub fn set_slot(&mut self, slot: usize, item: Option, item_allowed_override: bool) { + match slot { + 0 => { + // TODO: Add crafting check here + self.crafting_output = item + } + 1..=4 => { + self.crafting[slot-1] = item + } + 5..=8 => { + match item { + None => { + self.armor[slot-4] = None + }, + Some(item) => { + // TODO: Replace asserts with error handling + match slot-5 { + 0 => { + assert!(item.is_helmet() || item_allowed_override); + self.armor[0] = Some(item); + } + 1 => { + assert!(item.is_chestplate() || item_allowed_override); + self.armor[1] = Some(item) + } + 2 => { + assert!(item.is_leggings() || item_allowed_override); + self.armor[2] = Some(item); + } + 3 => { + assert!(item.is_boots() || item_allowed_override); + self.armor[3] = Some(item) + } + _ => unreachable!() + } + } + } + } + 9..=44 => { + self.items[slot-9] = item; + } + 45 => { + self.offhand = item; + } + _ => unreachable!() + } + } pub fn set_selected(&mut self, slot: usize) { assert!((0..9).contains(&slot)); From 3d21a991a0057db9f81ead6a06bfc464c42de82c Mon Sep 17 00:00:00 2001 From: Edvin Bryntesson Date: Tue, 20 Aug 2024 10:13:19 +0200 Subject: [PATCH 07/15] rename item_categories.rs --- .../src/item/{item_category_checks.rs => item_categories.rs} | 0 pumpkin-world/src/item/mod.rs | 2 +- 2 files changed, 1 insertion(+), 1 deletion(-) rename pumpkin-world/src/item/{item_category_checks.rs => item_categories.rs} (100%) diff --git a/pumpkin-world/src/item/item_category_checks.rs b/pumpkin-world/src/item/item_categories.rs similarity index 100% rename from pumpkin-world/src/item/item_category_checks.rs rename to pumpkin-world/src/item/item_categories.rs diff --git a/pumpkin-world/src/item/mod.rs b/pumpkin-world/src/item/mod.rs index 54c786fe..7bf44120 100644 --- a/pumpkin-world/src/item/mod.rs +++ b/pumpkin-world/src/item/mod.rs @@ -1,5 +1,5 @@ mod item_registry; -mod item_category_checks; +mod item_categories; #[derive(serde::Deserialize, Debug, Clone, PartialEq, Eq)] #[serde(rename_all = "lowercase")] From b2430ce3d44cfd6ffb56576768b7768424fc4f49 Mon Sep 17 00:00:00 2001 From: Edvin Bryntesson Date: Tue, 20 Aug 2024 11:23:21 +0200 Subject: [PATCH 08/15] make block place the item that is held. --- pumpkin-inventory/src/player.rs | 5 +++++ .../src/server/play/s_set_creative_slot.rs | 4 ++-- pumpkin-protocol/src/slot.rs | 22 ++++++++++++++++++- pumpkin-world/src/item/mod.rs | 4 ++-- pumpkin/src/client/player_packet.rs | 13 ++++++++--- 5 files changed, 40 insertions(+), 8 deletions(-) diff --git a/pumpkin-inventory/src/player.rs b/pumpkin-inventory/src/player.rs index 5b8aa2e4..9133a790 100644 --- a/pumpkin-inventory/src/player.rs +++ b/pumpkin-inventory/src/player.rs @@ -105,4 +105,9 @@ impl PlayerInventory { assert!((0..9).contains(&slot)); self.selected = slot; } + + pub fn held_item(&self) -> Option<&Item> { + debug_assert!((0..9).contains(&self.selected)); + self.items[self.selected+36-8].as_ref() + } } diff --git a/pumpkin-protocol/src/server/play/s_set_creative_slot.rs b/pumpkin-protocol/src/server/play/s_set_creative_slot.rs index 7a2cc4ad..ce0b7490 100644 --- a/pumpkin-protocol/src/server/play/s_set_creative_slot.rs +++ b/pumpkin-protocol/src/server/play/s_set_creative_slot.rs @@ -5,6 +5,6 @@ use crate::slot::Slot; #[derive(serde::Deserialize, Debug)] #[packet(0x32)] pub struct SSetCreativeSlot { - slot: i16, - clicked_item: Slot, + pub slot: i16, + pub clicked_item: Slot, } diff --git a/pumpkin-protocol/src/slot.rs b/pumpkin-protocol/src/slot.rs index f6b3d837..c79a211d 100644 --- a/pumpkin-protocol/src/slot.rs +++ b/pumpkin-protocol/src/slot.rs @@ -2,7 +2,7 @@ use serde::{ de::{self, SeqAccess, Visitor}, Deserialize, }; - +use pumpkin_world::item::Item; use crate::VarInt; #[derive(Debug, Clone)] @@ -15,6 +15,9 @@ pub struct Slot { components_to_remove: Option>, } + + + impl<'de> Deserialize<'de> for Slot { fn deserialize(deserializer: D) -> Result where @@ -74,3 +77,20 @@ impl<'de> Deserialize<'de> for Slot { deserializer.deserialize_seq(VarIntVisitor) } } +impl Slot { + pub fn to_item(self) -> Option { + let item_id = self.item_id?.0.try_into().unwrap(); + Some(Item { + item_id, + item_count: self.item_count.0.try_into().unwrap(), + }) + } +} +impl From for Item { + fn from(slot: Slot) -> Self { + Item { + item_count: slot.item_count.0.try_into().unwrap(), + item_id: slot.item_id.unwrap().0.try_into().unwrap() + } + } +} \ No newline at end of file diff --git a/pumpkin-world/src/item/mod.rs b/pumpkin-world/src/item/mod.rs index 7bf44120..c0e11907 100644 --- a/pumpkin-world/src/item/mod.rs +++ b/pumpkin-world/src/item/mod.rs @@ -13,8 +13,8 @@ pub enum Rarity { #[derive(Clone, Copy)] pub struct Item { - item_count: u32, + pub item_count: u32, // This ID is the numerical protocol ID, not the usual minecraft::block ID. - item_id: u32, + pub item_id: u32, // TODO: Add Item Components } diff --git a/pumpkin/src/client/player_packet.rs b/pumpkin/src/client/player_packet.rs index 0904e1b9..78fd3b7f 100644 --- a/pumpkin/src/client/player_packet.rs +++ b/pumpkin/src/client/player_packet.rs @@ -322,7 +322,11 @@ impl Client { let location = use_item_on.location; let face = BlockFace::from_i32(use_item_on.face.0).unwrap(); let location = WorldPosition(location.0 + face.to_offset()); - server.broadcast_packet(self, &CBlockUpdate::new(location, 11.into())); + // TODO: + // - Add checking for if used item is a block + if let Some(item) = self.player.as_ref().unwrap().inventory.held_item() { + server.broadcast_packet(self, &CBlockUpdate::new(location, item.item_id.into())); + } } pub fn handle_set_held_item(&mut self, _server: &mut Server, held: SSetHeldItem) { @@ -335,7 +339,10 @@ impl Client { } pub fn handle_set_creative_slot(&mut self, _server: &mut Server, packet: SSetCreativeSlot) { - // TODO: handle this - dbg!(&packet); + let inventory = &mut self.player.as_mut() + .unwrap() + .inventory; + + inventory.set_slot(packet.slot as usize, packet.clicked_item.to_item(), false); } } From 23613194a76b533ac259c6d685805178c9b47c57 Mon Sep 17 00:00:00 2001 From: Edvin Bryntesson Date: Tue, 20 Aug 2024 11:35:28 +0200 Subject: [PATCH 09/15] fix off by one error --- pumpkin-inventory/src/player.rs | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/pumpkin-inventory/src/player.rs b/pumpkin-inventory/src/player.rs index 9133a790..72afef94 100644 --- a/pumpkin-inventory/src/player.rs +++ b/pumpkin-inventory/src/player.rs @@ -108,6 +108,6 @@ impl PlayerInventory { pub fn held_item(&self) -> Option<&Item> { debug_assert!((0..9).contains(&self.selected)); - self.items[self.selected+36-8].as_ref() + self.items[self.selected+36-9].as_ref() } } From 47a7117fea1d264db420c404ffcb2a351c409875 Mon Sep 17 00:00:00 2001 From: Edvin Bryntesson Date: Tue, 20 Aug 2024 12:29:39 +0200 Subject: [PATCH 10/15] fix error message --- pumpkin-world/src/global_registry.rs | 1 + 1 file changed, 1 insertion(+) diff --git a/pumpkin-world/src/global_registry.rs b/pumpkin-world/src/global_registry.rs index 57ff7ea1..fd88c08a 100644 --- a/pumpkin-world/src/global_registry.rs +++ b/pumpkin-world/src/global_registry.rs @@ -15,6 +15,7 @@ pub struct RegistryElement { lazy_static! { static ref REGISTRY: HashMap = serde_json::from_str(REGISTRY_JSON).expect("Could not parse items.json registry."); + serde_json::from_str(REGISTRY_JSON).expect("Could not parse registry.json registry."); } pub fn get_protocol_id(category: &str, entry: &str) -> u32 { From f4ab2ce5857508c987a1e97d52b9255607473e6f Mon Sep 17 00:00:00 2001 From: Edvin Bryntesson Date: Tue, 20 Aug 2024 12:30:42 +0200 Subject: [PATCH 11/15] fix global registry and add function to easily access minecraft ids --- pumpkin-world/src/global_registry.rs | 14 +++++++++++--- 1 file changed, 11 insertions(+), 3 deletions(-) diff --git a/pumpkin-world/src/global_registry.rs b/pumpkin-world/src/global_registry.rs index fd88c08a..150562c6 100644 --- a/pumpkin-world/src/global_registry.rs +++ b/pumpkin-world/src/global_registry.rs @@ -9,12 +9,11 @@ const REGISTRY_JSON: &str = include_str!("../assets/registries.json"); #[derive(serde::Deserialize, Debug, Clone, PartialEq, Eq)] pub struct RegistryElement { default: Option, - entries: HashMap, + pub entries: HashMap>, } lazy_static! { - static ref REGISTRY: HashMap = - serde_json::from_str(REGISTRY_JSON).expect("Could not parse items.json registry."); + pub static ref REGISTRY: HashMap = serde_json::from_str(REGISTRY_JSON).expect("Could not parse registry.json registry."); } @@ -24,6 +23,7 @@ pub fn get_protocol_id(category: &str, entry: &str) -> u32 { .expect("Invalid Category in registry") .entries .get(entry) + .map(|p|p.get("protocol_id").unwrap()) .expect("No Entry found") } @@ -34,3 +34,11 @@ pub fn get_default<'a>(category: &str) -> Option<&'a str> { .default .as_deref() } + +pub fn find_minecraft_id(category: &str, protocol_id: u32) -> Option<&str> { + REGISTRY.get(category)? + .entries + .iter() + .find(|(_,other_protocol_id)|*other_protocol_id.get("protocol_id").unwrap()==protocol_id) + .map(|(id,_)|id.as_str()) +} From 1b1300e1940b15dfdcc969ddc32555b6c98c2c3a Mon Sep 17 00:00:00 2001 From: Edvin Bryntesson Date: Tue, 20 Aug 2024 12:31:46 +0200 Subject: [PATCH 12/15] make registries public --- pumpkin-world/src/block/block_registry.rs | 8 ++++---- pumpkin-world/src/block/mod.rs | 2 +- pumpkin-world/src/item/item_registry.rs | 4 ++-- pumpkin-world/src/item/mod.rs | 2 +- 4 files changed, 8 insertions(+), 8 deletions(-) diff --git a/pumpkin-world/src/block/block_registry.rs b/pumpkin-world/src/block/block_registry.rs index e44de504..f694bdca 100644 --- a/pumpkin-world/src/block/block_registry.rs +++ b/pumpkin-world/src/block/block_registry.rs @@ -7,28 +7,28 @@ use crate::world::WorldError; const BLOCKS_JSON: &str = include_str!("../../assets/blocks.json"); #[derive(serde::Deserialize, Debug, Clone, PartialEq, Eq)] -struct BlockDefinition { +pub struct BlockDefinition { #[serde(rename = "type")] kind: String, block_set_type: Option, } #[derive(serde::Deserialize, Debug, Clone, PartialEq, Eq)] -struct BlockState { +pub struct BlockState { default: Option, id: i64, properties: Option>, } #[derive(serde::Deserialize, Debug, Clone, PartialEq, Eq)] -struct BlocksElement { +pub struct BlocksElement { definition: BlockDefinition, properties: Option>>, states: Vec, } lazy_static! { - static ref BLOCKS: HashMap = + pub static ref BLOCKS: HashMap = serde_json::from_str(BLOCKS_JSON).expect("Could not parse block.json registry."); } diff --git a/pumpkin-world/src/block/mod.rs b/pumpkin-world/src/block/mod.rs index 6840d84d..1009f9fe 100644 --- a/pumpkin-world/src/block/mod.rs +++ b/pumpkin-world/src/block/mod.rs @@ -3,7 +3,7 @@ use num_derive::FromPrimitive; use crate::vector3::Vector3; pub mod block_registry; - +pub use block_registry::BLOCKS; #[derive(FromPrimitive)] pub enum BlockFace { Bottom = 0, diff --git a/pumpkin-world/src/item/item_registry.rs b/pumpkin-world/src/item/item_registry.rs index 278d793f..b521fd56 100644 --- a/pumpkin-world/src/item/item_registry.rs +++ b/pumpkin-world/src/item/item_registry.rs @@ -23,12 +23,12 @@ pub struct ItemComponents { } #[derive(serde::Deserialize, Debug, Clone, PartialEq, Eq)] -struct ItemElement { +pub struct ItemElement { components: ItemComponents, } lazy_static! { - static ref ITEMS: HashMap = + pub static ref ITEMS: HashMap = serde_json::from_str(ITEMS_JSON).expect("Could not parse items.json registry."); } diff --git a/pumpkin-world/src/item/mod.rs b/pumpkin-world/src/item/mod.rs index c0e11907..0fa843d5 100644 --- a/pumpkin-world/src/item/mod.rs +++ b/pumpkin-world/src/item/mod.rs @@ -1,6 +1,6 @@ mod item_registry; mod item_categories; - +pub use item_registry::ITEMS; #[derive(serde::Deserialize, Debug, Clone, PartialEq, Eq)] #[serde(rename_all = "lowercase")] /// Item Rarity From c18cbdc06b15d59a7b47952bea9ae9f85f62aa7b Mon Sep 17 00:00:00 2001 From: Edvin Bryntesson Date: Tue, 20 Aug 2024 12:32:05 +0200 Subject: [PATCH 13/15] add logic for placing blocks --- pumpkin-world/src/lib.rs | 2 +- pumpkin/src/client/player_packet.rs | 10 ++++++---- 2 files changed, 7 insertions(+), 5 deletions(-) diff --git a/pumpkin-world/src/lib.rs b/pumpkin-world/src/lib.rs index 209451eb..81fe81f8 100644 --- a/pumpkin-world/src/lib.rs +++ b/pumpkin-world/src/lib.rs @@ -4,7 +4,7 @@ pub const WORLD_HEIGHT: usize = 384; pub const WORLD_Y_START_AT: i32 = -64; pub const DIRECT_PALETTE_BITS: u32 = 15; pub mod block; -mod global_registry; +pub mod global_registry; pub mod item; pub mod radial_chunk_iterator; pub mod vector3; diff --git a/pumpkin/src/client/player_packet.rs b/pumpkin/src/client/player_packet.rs index 78fd3b7f..9dc7f864 100644 --- a/pumpkin/src/client/player_packet.rs +++ b/pumpkin/src/client/player_packet.rs @@ -17,7 +17,7 @@ use pumpkin_protocol::{ }; use pumpkin_text::TextComponent; use pumpkin_world::block::BlockFace; - +use pumpkin_world::global_registry; use crate::{ commands::{handle_command, CommandSender}, entity::player::{ChatMode, GameMode, Hand}, @@ -322,10 +322,12 @@ impl Client { let location = use_item_on.location; let face = BlockFace::from_i32(use_item_on.face.0).unwrap(); let location = WorldPosition(location.0 + face.to_offset()); - // TODO: + // TODO: // - Add checking for if used item is a block if let Some(item) = self.player.as_ref().unwrap().inventory.held_item() { - server.broadcast_packet(self, &CBlockUpdate::new(location, item.item_id.into())); + let id = global_registry::find_minecraft_id(global_registry::ITEM_REGISTRY,item.item_id).unwrap(); + let block_state_id = pumpkin_world::block::block_registry::block_id_and_properties_to_block_state_id(id,None).expect("Id should exist"); + server.broadcast_packet(self, &CBlockUpdate::new(location, (block_state_id as i32).into())); } } @@ -342,7 +344,7 @@ impl Client { let inventory = &mut self.player.as_mut() .unwrap() .inventory; - + inventory.set_slot(packet.slot as usize, packet.clicked_item.to_item(), false); } } From 65d9f394550384c8922fb7625e77ff7d1db24365 Mon Sep 17 00:00:00 2001 From: Edvin Bryntesson Date: Tue, 20 Aug 2024 12:45:21 +0200 Subject: [PATCH 14/15] better naming --- pumpkin/src/client/player_packet.rs | 6 +++--- 1 file changed, 3 insertions(+), 3 deletions(-) diff --git a/pumpkin/src/client/player_packet.rs b/pumpkin/src/client/player_packet.rs index 9dc7f864..660f8e59 100644 --- a/pumpkin/src/client/player_packet.rs +++ b/pumpkin/src/client/player_packet.rs @@ -318,15 +318,15 @@ impl Client { } pub fn handle_player_action(&mut self, _server: &mut Server, player_action: SPlayerAction) {} - pub fn handle_use_item_on(&mut self, server: &mut Server, use_item_on: SUseItemOn) { + pub fn handle_use_item_on(&mut self, server: &mut Server, use_item_on: SUseItemOn) { let location = use_item_on.location; let face = BlockFace::from_i32(use_item_on.face.0).unwrap(); let location = WorldPosition(location.0 + face.to_offset()); // TODO: // - Add checking for if used item is a block if let Some(item) = self.player.as_ref().unwrap().inventory.held_item() { - let id = global_registry::find_minecraft_id(global_registry::ITEM_REGISTRY,item.item_id).unwrap(); - let block_state_id = pumpkin_world::block::block_registry::block_id_and_properties_to_block_state_id(id,None).expect("Id should exist"); + let minecraft_id = global_registry::find_minecraft_id(global_registry::ITEM_REGISTRY,item.item_id).unwrap(); + let block_state_id = pumpkin_world::block::block_registry::block_id_and_properties_to_block_state_id(minecraft_id,None).expect("Id should exist"); server.broadcast_packet(self, &CBlockUpdate::new(location, (block_state_id as i32).into())); } } From e86889f4c09bf9b822557bf1c5ba1b16f3284a29 Mon Sep 17 00:00:00 2001 From: Edvin Bryntesson Date: Tue, 20 Aug 2024 12:48:27 +0200 Subject: [PATCH 15/15] fix so that right-clicking with non-blocks is possible --- pumpkin/src/client/player_packet.rs | 9 ++++----- 1 file changed, 4 insertions(+), 5 deletions(-) diff --git a/pumpkin/src/client/player_packet.rs b/pumpkin/src/client/player_packet.rs index 660f8e59..f9c6db66 100644 --- a/pumpkin/src/client/player_packet.rs +++ b/pumpkin/src/client/player_packet.rs @@ -322,12 +322,11 @@ impl Client { let location = use_item_on.location; let face = BlockFace::from_i32(use_item_on.face.0).unwrap(); let location = WorldPosition(location.0 + face.to_offset()); - // TODO: - // - Add checking for if used item is a block if let Some(item) = self.player.as_ref().unwrap().inventory.held_item() { - let minecraft_id = global_registry::find_minecraft_id(global_registry::ITEM_REGISTRY,item.item_id).unwrap(); - let block_state_id = pumpkin_world::block::block_registry::block_id_and_properties_to_block_state_id(minecraft_id,None).expect("Id should exist"); - server.broadcast_packet(self, &CBlockUpdate::new(location, (block_state_id as i32).into())); + let minecraft_id = global_registry::find_minecraft_id(global_registry::ITEM_REGISTRY,item.item_id).expect("All item ids are in the global registry"); + if let Ok(block_state_id) = pumpkin_world::block::block_registry::block_id_and_properties_to_block_state_id(minecraft_id,None) { + server.broadcast_packet(self, &CBlockUpdate::new(location, (block_state_id as i32).into())); + } } }