Skip to main content

ItemStack

Struct ItemStack 

Source
pub struct ItemStack {
    pub item: ItemRef,
    pub count: i32,
    patch: DataComponentPatch,
}
Expand description

A stack of items with a count and component modifications.

Fields§

§item: ItemRef

The item type. AIR represents an empty stack.

§count: i32

The number of items in this stack.

§patch: DataComponentPatch

Modifications to the prototype components.

Implementations§

Source§

impl ItemStack

Source

pub fn empty() -> Self

Creates an empty item stack (using AIR).

Source

pub fn new(item: ItemRef) -> Self

Creates a new item stack with count 1.

Source

pub fn with_count(item: ItemRef, count: i32) -> Self

Creates a new item stack with the specified count.

Source

pub fn with_count_and_patch( item: ItemRef, count: i32, patch: DataComponentPatch, ) -> Self

Creates a new item stack with the specified count and component patch.

Source

fn prototype(&self) -> &'static DataComponentMap

Source

pub fn is_empty(&self) -> bool

Source

pub fn item(&self) -> ItemRef

Source

pub fn count(&self) -> i32

Source

pub fn set_count(&mut self, count: i32)

Source

pub fn grow(&mut self, amount: i32)

Increases the count by the given amount.

Source

pub fn shrink(&mut self, amount: i32)

Decreases the count by the given amount.

Source

pub fn split(&mut self, amount: i32) -> Self

Splits off the specified amount from this stack and returns it as a new stack.

If the amount is greater than or equal to the current count, this stack becomes empty and the entire contents are returned.

Source

pub fn copy_with_count(&self, count: i32) -> Self

Copies the identity (item type and patch) from another stack.

Used when splitting stacks to preserve components.

Source

pub fn is_stackable(&self) -> bool

Returns true if this item can stack (max stack size > 1 and not damaged). Damaged items cannot stack.

Source

pub fn is_damageable_item(&self) -> bool

Returns true if this item can take damage.

Source

pub fn is_damaged(&self) -> bool

Returns true if this item has taken damage.

Source

pub fn get_damage_value(&self) -> i32

Gets the current damage value of this item.

Source

pub fn set_damage_value(&mut self, value: i32)

Sets the damage value of this item.

Source

pub fn get_max_damage(&self) -> i32

Gets the maximum damage this item can take before breaking.

Source

pub fn is_broken(&self) -> bool

Returns true if the item is broken (damage >= max damage).

Source

pub fn next_damage_will_break(&self) -> bool

Returns vanilla ItemStack.nextDamageWillBreak().

Source

pub fn hurt_and_break( &mut self, amount: i32, has_infinite_materials: bool, ) -> bool

Damages the item and breaks it if durability reaches zero.

Returns true if the item broke and should be removed/replaced.

Source

pub fn has<T: 'static>(&self, component: DataComponentType<T>) -> bool

Returns true if this item has the specified component (by type).

Source

pub fn has_component(&self, key: &Identifier) -> bool

Returns true if this item has the specified component (by key).

Source

pub fn is_same_item(a: &Self, b: &Self) -> bool

Source

pub fn is_same_item_same_components(a: &Self, b: &Self) -> bool

Checks if two stacks have the same item and components.

Source

pub fn matches(a: &Self, b: &Self) -> bool

Source

pub fn is(&self, item: ItemRef) -> bool

Source

pub fn max_stack_size(&self) -> i32

Source

pub fn get_equippable(&self) -> Option<&Equippable>

Returns the equippable component if this item has one.

Source

pub fn get_equippable_slot(&self) -> Option<EquippableSlot>

Returns the equipment slot this item can be equipped to, if any.

Source

pub fn is_equippable_in_slot(&self, slot: EquippableSlot) -> bool

Returns true if this item can be equipped in the given slot.

Source

pub fn get_effective_value_raw( &self, key: &Identifier, ) -> Option<&ComponentData>

Gets the raw component data by key.

Source

pub fn get<T: Component>(&self, component: DataComponentType<T>) -> Option<&T>

Gets the effective value of a component, considering the patch and prototype. Returns None if the component is not present or has been removed.

Source

pub fn get_or_default<T: Component>( &self, component: DataComponentType<T>, default: T, ) -> T

Gets the effective value of a component, or returns the default value if not present.

Source

pub fn set<T: Component>(&mut self, component: DataComponentType<T>, value: T)

Sets a component value in this item’s patch, overriding the prototype.

Source

pub fn remove<T: 'static>(&mut self, component: DataComponentType<T>)

Removes a component from this item (marks it as removed in the patch). This will hide the component even if it exists in the prototype.

Source

pub fn clear<T: 'static>(&mut self, component: DataComponentType<T>)

Clears any patch entry for this component (neither set nor removed). The prototype value will be visible again.

Source

pub fn patch(&self) -> &DataComponentPatch

Returns a reference to the component patch.

Source

pub fn get_tool(&self) -> Option<&Tool>

Gets the Tool component if present.

Source

pub fn get_destroy_speed(&self, block_state_id: BlockStateId) -> f32

Returns the mining speed for the given block state ID. If no Tool component is present, returns 1.0 (hand speed).

Source

pub fn is_correct_tool_for_drops(&self, block_state_id: BlockStateId) -> bool

Returns true if this tool is correct for getting drops from the block.

Source

pub fn get_tool_damage_per_block(&self) -> i32

Returns the damage per block for this tool (how much durability is consumed per block mined). Returns 0 if no Tool component is present.

Source

pub fn can_destroy_blocks_in_creative(&self) -> bool

Returns true if this tool can destroy blocks in creative mode. Returns true if no Tool component is present (default behavior).

Source

pub fn get_enchantment_level(&self, enchantment: &Identifier) -> i32

Source

pub fn get_enchantments(&self) -> Option<&ItemEnchantments>

Source

pub fn set_damage_fraction(&mut self, _fraction: f32, _add: bool)

Sets the damage/durability as a fraction (0.0 = broken, 1.0 = full). If add is true, adds to current damage instead of setting.

Source

pub fn enchant_randomly<R: Rng>( &mut self, _options: &EnchantmentOptions, _rng: &mut R, )

Enchants this item randomly with enchantments from the given options.

Source

pub fn enchant_with_levels<R: Rng>( &mut self, _level: i32, _options: &EnchantmentOptions, _rng: &mut R, )

Enchants this item as if using an enchanting table at the given level.

Source

pub fn copy_components<R: Rng>( &mut self, _source: CopySource, _include: &[Identifier], _ctx: &LootContext<'_, R>, )

Copies components from a source (block entity, attacker, etc.) to this item.

Source

pub fn copy_block_state<R: Rng>( &mut self, _block: &Identifier, _properties: &[&str], _ctx: &LootContext<'_, R>, )

Copies block state properties to this item (for blocks like note_block).

Source

pub fn set_components_from_json(&mut self, _components: &str)

Sets components from a JSON string representation.

Source

pub fn set_custom_data(&mut self, _tag: &str)

Sets custom NBT data on this item (merges with existing custom_data).

Source

pub fn apply_furnace_smelt(&mut self)

Applies furnace smelting to convert this item (e.g., raw iron -> iron ingot).

Source

pub fn create_exploration_map( &mut self, _destination: &Identifier, _decoration: &Identifier, _zoom: i32, _skip_existing_chunks: bool, )

Creates an exploration map pointing to a structure.

Source

pub fn set_name(&mut self, _name: &str, _target: NameTarget)

Sets the custom name or item name of this item.

Source

pub fn set_ominous_bottle_amplifier(&mut self, _amplifier: i32)

Sets the ominous bottle amplifier.

Source

pub fn set_potion(&mut self, _id: &Identifier)

Sets the potion type for this item.

Source

pub fn set_stew_effects<R: Rng>( &mut self, _effects: &[StewEffect], _rng: &mut R, )

Sets the suspicious stew effects for this item.

Source

pub fn set_instrument<R: Rng>(&mut self, _options: &Identifier, _rng: &mut R)

Sets the instrument for a goat horn.

Source

pub fn set_enchantments( &mut self, enchantments: &[(Identifier, u32)], add: bool, )

Source

pub fn upgrade_enchantment(&mut self, enchantment: Identifier, level: u32)

Vanilla ItemStack.enchantMutable.upgrade: keeps the higher of existing vs new level.

Source

pub fn set_item(&mut self, new_item: &Identifier)

Changes the item type entirely.

Source

pub fn copy_name<R: Rng>( &mut self, _source: CopySource, _ctx: &LootContext<'_, R>, )

Copies the name from a source entity/block to this item.

Source

pub fn set_lore(&mut self, _lore: &[&str], _mode: ListOperation)

Sets lore lines on this item.

Source

pub fn set_contents<R: Rng>( &mut self, _entries: &[LootEntry], _component_type: &Identifier, _ctx: &mut LootContext<'_, R>, )

Sets container inventory contents.

Source

pub fn modify_contents<R: Rng>( &mut self, _modifier: &[ConditionalLootFunction], _component_type: &Identifier, _ctx: &mut LootContext<'_, R>, )

Modifies existing container contents.

Source

pub fn set_loot_table(&mut self, _loot_table: &Identifier, _seed: Option<i64>)

Sets the container’s loot table reference.

Source

pub fn set_attributes<R: Rng>( &mut self, _modifiers: &[AttributeModifier], _replace: bool, _rng: &mut R, )

Sets attribute modifiers on this item.

Source

pub fn fill_player_head<R: Rng>( &mut self, _entity: LootContextEntity, _ctx: &LootContext<'_, R>, )

Fills a player head with texture from an entity.

Source

pub fn copy_custom_data<R: Rng>( &mut self, _source: CopySource, _operations: &[CopyDataOperation], _ctx: &LootContext<'_, R>, )

Copies custom NBT data from a source.

Source

pub fn set_banner_pattern(&mut self, _patterns: &[BannerPattern], _append: bool)

Sets banner pattern layers.

Source

pub fn set_fireworks( &mut self, _explosions: Option<&[FireworkExplosion]>, _flight_duration: Option<i32>, )

Sets firework rocket properties.

Source

pub fn set_firework_explosion(&mut self, _explosion: &FireworkExplosion)

Sets firework star explosion properties.

Source

pub fn set_book_cover( &mut self, _title: Option<&str>, _author: Option<&str>, _generation: Option<i32>, )

Sets book cover (title/author for written books).

Source

pub fn set_written_book_pages(&mut self, _pages: &[&str], _mode: ListOperation)

Sets written book page contents.

Source

pub fn set_writable_book_pages(&mut self, _pages: &[&str], _mode: ListOperation)

Sets writable book page contents.

Source

pub fn toggle_tooltips(&mut self, _toggles: &[(Identifier, bool)])

Toggles tooltip visibility for components.

Source

pub fn set_custom_model_data(&mut self, _value: i32)

Sets custom model data.

Source

pub fn components_equal(&self, other: &Self) -> bool

Source§

impl ItemStack

Source

pub fn read_untrusted(data: &mut Cursor<&[u8]>) -> Result<Self>

Reads an item stack using the delimited (untrusted) component format.

Vanilla uses this for serverbound packets where component data is length-prefixed (e.g., ServerboundSetCreativeModeSlotPacket).

Source§

impl ItemStack

Source

pub fn to_nbt_tag_ref(&self) -> NbtTag

Converts this item stack to an NBT tag for persistent storage without consuming it.

Source§

impl ItemStack

Source

pub fn from_borrowed_compound( compound: &NbtCompoundView<'_, '_>, ) -> Option<Self>

Parses an ItemStack from a borrowed NbtCompoundView.

This is useful for loading items from disk where we have borrowed NBT data and want to avoid the overhead of converting to an owned tag first.

Trait Implementations§

Source§

impl Clone for ItemStack

Source§

fn clone(&self) -> ItemStack

Returns a duplicate of the value. Read more
1.0.0 (const: unstable) · Source§

fn clone_from(&mut self, source: &Self)

Performs copy-assignment from source. Read more
Source§

impl Debug for ItemStack

Source§

fn fmt(&self, f: &mut Formatter<'_>) -> Result

Formats the value using the given formatter. Read more
Source§

impl Default for ItemStack

Source§

fn default() -> Self

Returns the “default value” for a type. Read more
Source§

impl Display for ItemStack

Source§

fn fmt(&self, f: &mut Formatter<'_>) -> Result

Formats the value using the given formatter. Read more
Source§

impl FromNbtTag for ItemStack

Source§

fn from_nbt_tag(tag: BorrowedNbtTag<'_, '_>) -> Option<Self>

Parses an item stack from an NBT tag.

Accepts the vanilla format:

{
    id: "minecraft:stone",
    count: 64,
    components: { ... }
}
§

fn from_optional_nbt_tag( tag: Option<NbtTag<'_, '_>>, ) -> Result<Option<Self>, DeserializeError>

Source§

impl PartialEq for ItemStack

Source§

fn eq(&self, other: &ItemStack) -> bool

Tests for self and other values to be equal, and is used by ==.
1.0.0 (const: unstable) · Source§

fn ne(&self, other: &Rhs) -> bool

Tests for !=. The default implementation is almost always sufficient, and should not be overridden without very good reason.
Source§

impl ReadFrom for ItemStack

Source§

fn read(data: &mut Cursor<&[u8]>) -> Result<Self>

Reads data from a cursor.
Source§

impl StructuralPartialEq for ItemStack

Source§

impl ToNbtTag for ItemStack

Source§

fn to_nbt_tag(self) -> NbtTag

Converts this item stack to an NBT tag for persistent storage.

Format (matching vanilla Minecraft):

{
    id: "minecraft:stone",
    count: 64,
    components: { ... }  // Only present if patch is non-empty
}
§

fn to_optional_nbt_tag(self) -> Option<NbtTag>

Source§

impl WriteTo for ItemStack

Source§

fn write(&self, writer: &mut impl Write) -> Result<()>

Writes data to a writer.

Auto Trait Implementations§

Blanket Implementations§

Source§

impl<T> Any for T
where T: 'static + ?Sized,

Source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
Source§

impl<T> Borrow<T> for T
where T: ?Sized,

Source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
Source§

impl<T> BorrowMut<T> for T
where T: ?Sized,

Source§

fn borrow_mut(&mut self) -> &mut T

Mutably borrows from an owned value. Read more
Source§

impl<T> CloneToUninit for T
where T: Clone,

Source§

unsafe fn clone_to_uninit(&self, dest: *mut u8)

🔬This is a nightly-only experimental API. (clone_to_uninit)
Performs copy-assignment from self to dest. Read more
Source§

impl<T> From<T> for T

Source§

fn from(t: T) -> T

Returns the argument unchanged.

§

impl<T> Instrument for T

§

fn instrument(self, span: Span) -> Instrumented<Self>

Instruments this type with the provided [Span], returning an Instrumented wrapper. Read more
§

fn in_current_span(self) -> Instrumented<Self>

Instruments this type with the current Span, returning an Instrumented wrapper. Read more
Source§

impl<T, U> Into<U> for T
where U: From<T>,

Source§

fn into(self) -> U

Calls U::from(self).

That is, this conversion is whatever the implementation of From<T> for U chooses to do.

Source§

impl<T> ToOwned for T
where T: Clone,

Source§

type Owned = T

The resulting type after obtaining ownership.
Source§

fn to_owned(&self) -> T

Creates owned data from borrowed data, usually by cloning. Read more
Source§

fn clone_into(&self, target: &mut T)

Uses borrowed data to replace owned data, usually by cloning. Read more
Source§

impl<T> ToString for T
where T: Display + ?Sized,

Source§

fn to_string(&self) -> String

Converts the given value to a String. Read more
Source§

impl<T, U> TryFrom<U> for T
where U: Into<T>,

Source§

type Error = Infallible

The type returned in the event of a conversion error.
Source§

fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>

Performs the conversion.
Source§

impl<T, U> TryInto<U> for T
where U: TryFrom<T>,

Source§

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.
Source§

fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>

Performs the conversion.
§

impl<T> WithSubscriber for T

§

fn with_subscriber<S>(self, subscriber: S) -> WithDispatch<Self>
where S: Into<Dispatch>,

Attaches the provided Subscriber to this type, returning a [WithDispatch] wrapper. Read more
§

fn with_current_subscriber(self) -> WithDispatch<Self>

Attaches the current default Subscriber to this type, returning a [WithDispatch] wrapper. Read more