MCItemStackMutable

Link to mcitemstackmutable

Importare la Classe

Link to importare-la-classe

It might be required for you to import the package if you encounter any issues (like casting an Array), so better be safe than sorry and add the import at the very top of the file.

ZenScript
Copy
import crafttweaker.api.item.MCItemStackMutable;

Interfacce Implementate

Link to interfacce-implementate

MCItemStackMutable implements the following interfaces. That means all methods defined in these interfaces are also available in MCItemStackMutable

Static Properties

Link to static-properties

NomeTipoHa GetterHa Setter
Nome
BASE_ATTACK_DAMAGE_UUID
Tipo
invalid
Ha Getter
Ha Setter
no
Nome
BASE_ATTACK_SPEED_UUID
Tipo
invalid
Ha Getter
Ha Setter
no
Nome
CRAFTTWEAKER_DATA_KEY
Tipo
string
Ha Getter
Ha Setter
no
Result TypeImplicito
Result Type
IIngredientWithAmount
Implicito
Result Type
ItemDefinition
Implicito
Result Type
ItemLike
Implicito
Result Type
MapData
Implicito
Result Type
Percentaged<IItemStack>
Implicito

Link to addGlobalAttributeModifier

Name: addGlobalAttributeModifier

Adds an AttributeModifier to this IIngredient.

Attributes added with this method appear on all ItemStacks that match this IIngredient, regardless of how or when the ItemStack was made, if you want to have the attribute on a single specific ItemStack (such as a specific Diamond Sword made in a recipe), then you should use IItemStack#withAttributeModifier

ZenScript
Copy
// MCItemStackMutable.addGlobalAttributeModifier(attribute as Attribute, name as string, value as double, operation as AttributeOperation, slotTypes as EquipmentSlot[])

myMCItemStackMutable.addGlobalAttributeModifier(<attribute:minecraft:generic.attack_damage>, "Extra Power", 10, AttributeOperation.ADDITION, [<constant:minecraft:equipmentslot:chest>]);
ParametroTipoDescrizione
Parametro
attribute
Tipo
Attribute
Descrizione
The Attribute of the modifier.
Parametro
nome
Tipo
string
Descrizione
The name of the modifier.
Parametro
valore
Tipo
double
Descrizione
The value of the modifier.
Parametro
operation
Tipo
AttributeOperation
Descrizione
The operation of the modifier.
Parametro
slotTypes
Tipo
EquipmentSlot[]
Descrizione
What slots the modifier is valid for.

Link to addGlobalAttributeModifier

Name: addGlobalAttributeModifier

Adds an AttributeModifier to this IIngredient using a specific UUID.

The UUID can be used to override an existing attribute on an ItemStack with this new modifier. You can use /ct hand attributes to get the UUID of the attributes on an ItemStack.

Attributes added with this method appear on all ItemStacks that match this IIngredient, regardless of how or when the ItemStack was made, if you want to have the attribute on a single specific ItemStack (such as a specific Diamond Sword made in a recipe), then you should use IItemStack#withAttributeModifier

ZenScript
Copy
// MCItemStackMutable.addGlobalAttributeModifier(attribute as Attribute, uuid as invalid, name as string, value as double, operation as AttributeOperation, slotTypes as EquipmentSlot[])

myMCItemStackMutable.addGlobalAttributeModifier(<attribute:minecraft:generic.attack_damage>, IItemStack.BASE_ATTACK_DAMAGE_UUID, "Extra Power", 10, AttributeOperation.ADDITION, [<constant:minecraft:equipmentslot:chest>]);
ParametroTipoDescrizione
Parametro
attribute
Tipo
Attribute
Descrizione
The Attribute of the modifier.
Parametro
uuid
Tipo
invalid
Descrizione
The unique identifier of the modifier to replace.
Parametro
nome
Tipo
string
Descrizione
The name of the modifier.
Parametro
valore
Tipo
double
Descrizione
The value of the modifier.
Parametro
operation
Tipo
AttributeOperation
Descrizione
The operation of the modifier.
Parametro
slotTypes
Tipo
EquipmentSlot[]
Descrizione
What slots the modifier is valid for.

Link to addGlobalAttributeModifier

Name: addGlobalAttributeModifier

Adds an AttributeModifier to this IIngredient using a specific UUID.

The UUID can be used to override an existing attribute on an ItemStack with this new modifier. You can use /ct hand attributes to get the UUID of the attributes on an ItemStack.

Attributes added with this method appear on all ItemStacks that match this IIngredient, regardless of how or when the ItemStack was made, if you want to have the attribute on a single specific ItemStack (such as a specific Diamond Sword made in a recipe), then you should use IItemStack#withAttributeModifier

ZenScript
Copy
// MCItemStackMutable.addGlobalAttributeModifier(attribute as Attribute, uuid as string, name as string, value as double, operation as AttributeOperation, slotTypes as EquipmentSlot[])

myMCItemStackMutable.addGlobalAttributeModifier(<attribute:minecraft:generic.attack_damage>, "8c1b5535-9f79-448b-87ae-52d81480aaa3", "Extra Power", 10, AttributeOperation.ADDITION, [<constant:minecraft:equipmentslot:chest>]);
ParametroTipoDescrizione
Parametro
attribute
Tipo
Attribute
Descrizione
The Attribute of the modifier.
Parametro
uuid
Tipo
string
Descrizione
The unique identifier of the modifier to replace.
Parametro
nome
Tipo
string
Descrizione
The name of the modifier.
Parametro
valore
Tipo
double
Descrizione
The value of the modifier.
Parametro
operation
Tipo
AttributeOperation
Descrizione
The operation of the modifier.
Parametro
slotTypes
Tipo
EquipmentSlot[]
Descrizione
What slots the modifier is valid for.

Name: addShiftTooltip

ZenScript
Copy
MCItemStackMutable.addShiftTooltip(content as Component, showMessage as Component)
ParametroTipoOptional
Parametro
contenuto
Tipo
Component
Optional
no
Parametro
showMessage
Tipo
Component
Optional

Name: addTooltip

ZenScript
Copy
MCItemStackMutable.addTooltip(content as Component)
ParametroTipo
Parametro
contenuto
Tipo
Component

Name: anyDamage

Return Type: IngredientConditioned<IIngredient>

ZenScript
Copy
// MCItemStackMutable.anyDamage() as IngredientConditioned<IIngredient>

myMCItemStackMutable.anyDamage();

Link to asIIngredientWithAmount

Name: asIIngredientWithAmount

Return Type: IIngredientWithAmount

ZenScript
Copy
// MCItemStackMutable.asIIngredientWithAmount() as IIngredientWithAmount

myMCItemStackMutable.asIIngredientWithAmount();

Name: asItemLike

Return Type: ItemLike

ZenScript
Copy
// MCItemStackMutable.asItemLike() as ItemLike

myMCItemStackMutable.asItemLike();

Name: clearTooltip

ZenScript
Copy
MCItemStackMutable.clearTooltip(leaveName as boolean)
ParametroTipoOptionalDefault Value
Parametro
leaveName
Tipo
boolean
Optional
Default Value
no

Name: contains

Does the ingredient contain the given ingredient?

Return Type: boolean

ZenScript
Copy
// MCItemStackMutable.contains(ingredient as IIngredient) as boolean

myMCItemStackMutable.contains((<item:minecraft:iron_ingot> | <item:minecraft:gold_ingot>));
ParametroTipoDescrizione
Parametro
ingredient
Tipo
IIngredient
Descrizione
The ingredient to check

Name: getAttributes

Gets the Attributes and the AttributeModifiers on this IItemStack for the given EquipmentSlot

Returns: A Map of Attribute to a List of AttributeModifier for the given EquipmentSlot.
Return Type: stdlib.List<AttributeModifier>[Attribute]

ZenScript
Copy
// MCItemStackMutable.getAttributes(slotType as EquipmentSlot) as stdlib.List<AttributeModifier>[Attribute]

myMCItemStackMutable.getAttributes(<constant:minecraft:equipmentslot:chest>);
ParametroTipoDescrizione
Parametro
slotType
Tipo
EquipmentSlot
Descrizione
The slot to get the Attributes for.

Name: getBurnTime

Return Type: int

ZenScript
Copy
MCItemStackMutable.getBurnTime(manager as IRecipeManager) as int
ParametroTipo
Parametro
manager
Tipo
IRecipeManager

Name: getDefinition

Return Type: ItemDefinition

ZenScript
Copy
// MCItemStackMutable.getDefinition() as ItemDefinition

myMCItemStackMutable.getDefinition();

Link to getEnchantmentLevel

Name: getEnchantmentLevel

Gets the level of the given enchantment on the item. Returns 0 if the item doesn't have the given enchantment.

Return Type: int

ZenScript
Copy
MCItemStackMutable.getEnchantmentLevel(enchantment as Enchantment) as int
ParametroTipo
Parametro
enchantment
Tipo
Enchantment

Name: getEnchantments

Return Type: int?[Enchantment]

ZenScript
Copy
// MCItemStackMutable.getEnchantments() as int?[Enchantment]

myMCItemStackMutable.getEnchantments();

Name: getFood

Return Type: FoodProperties?

ZenScript
Copy
// MCItemStackMutable.getFood() as FoodProperties?

myMCItemStackMutable.getFood();

Name: getHoverName

Gets the hover name of the ItemStack.

This will give the raw name without the formatting that 'displayName' applies.

Returns: The hover name of the ItemStack.
Return Type: Component

ZenScript
Copy
// MCItemStackMutable.getHoverName() as Component

myMCItemStackMutable.getHoverName();

Link to getImmutableInternal

Name: getImmutableInternal

Return Type: ItemStack

ZenScript
Copy
// MCItemStackMutable.getImmutableInternal() as ItemStack

myMCItemStackMutable.getImmutableInternal();

Name: getMaxStackSize

Returns the max stack size of the Item in the ItemStack

Returns: Max stack size of the Item.
Return Type: int

ZenScript
Copy
// MCItemStackMutable.getMaxStackSize() as int

myMCItemStackMutable.getMaxStackSize();

Name: getOrCreateTag

Returns the NBT tag attached to this ItemStack or makes a new tag.

Returns: MapData of the ItemStack NBT Tag, empty tag if it doesn't exist.
Return Type: IData

ZenScript
Copy
// MCItemStackMutable.getOrCreateTag() as IData

myMCItemStackMutable.getOrCreateTag();

Name: getRarity

Returns the rarity of the Item in the ItemStack

Returns: Rarity of the Item.
Return Type: Rarity

ZenScript
Copy
// MCItemStackMutable.getRarity() as Rarity

myMCItemStackMutable.getRarity();

Name: grow

Grows this IItemStack's stack size by the given amount, or 1 if no amount is given.

Returns: This IItemStack if mutable, a new one with the new amount otherwise.
Return Type: IItemStack

ZenScript
Copy
// MCItemStackMutable.grow(amount as int) as IItemStack

myMCItemStackMutable.grow(2);
ParametroTipoDescrizioneOptionalDefault Value
Parametro
amount
Tipo
int
Descrizione
The amount to grow by.
Optional
Default Value
1

Name: isEdible

Return Type: boolean

ZenScript
Copy
// MCItemStackMutable.isEdible() as boolean

myMCItemStackMutable.isEdible();

Name: isFireResistant

Checks if this IItemStack burns when thrown into fire / lava or damaged by fire.

Returns: True if this IItemStack is immune to fire. False otherwise.
Return Type: boolean

ZenScript
Copy
// MCItemStackMutable.isFireResistant() as boolean

myMCItemStackMutable.isFireResistant();

Name: isMutable

Return Type: boolean

ZenScript
Copy
// MCItemStackMutable.isMutable() as boolean

myMCItemStackMutable.isMutable();

Name: matches

Does the given stack match the ingredient?

Return Type: boolean

ZenScript
Copy
// MCItemStackMutable.matches(stack as IItemStack) as boolean

myMCItemStackMutable.matches(<item:minecraft:iron_ingot>);
ParametroTipoDescrizione
Parametro
stack
Tipo
IItemStack
Descrizione
The stack to check

Link to modifyShiftTooltip

Name: modifyShiftTooltip

ZenScript
Copy
MCItemStackMutable.modifyShiftTooltip(shiftedFunction as ITooltipFunction, unshiftedFunction as ITooltipFunction)
ParametroTipoOptional
Parametro
shiftedFunction
Tipo
ITooltipFunction
Optional
no
Parametro
unshiftedFunction
Tipo
ITooltipFunction
Optional

Name: modifyTooltip

ZenScript
Copy
MCItemStackMutable.modifyTooltip(function as ITooltipFunction)
ParametroTipo
Parametro
function
Tipo
ITooltipFunction

Name: mul

Use this in contexts where machines accept more than one item to state that fact.

Return Type: IIngredientWithAmount

ZenScript
Copy
MCItemStackMutable.mul(amount as int) as IIngredientWithAmount
ParametroTipo
Parametro
amount
Tipo
int

Name: only

Use this if you already have the condition from another ingredient

Return Type: IngredientConditioned<IIngredient>

ZenScript
Copy
MCItemStackMutable.only(condition as IIngredientCondition<IIngredient>) as IngredientConditioned<IIngredient>
ParametroTipo
Parametro
condition
Tipo
IIngredientCondition<IIngredient>

Name: onlyDamaged

Return Type: IngredientConditioned<IIngredient>

ZenScript
Copy
// MCItemStackMutable.onlyDamaged() as IngredientConditioned<IIngredient>

myMCItemStackMutable.onlyDamaged();

Link to onlyDamagedAtLeast

Name: onlyDamagedAtLeast

Return Type: IngredientConditioned<IIngredient>

ZenScript
Copy
MCItemStackMutable.onlyDamagedAtLeast(minDamage as int) as IngredientConditioned<IIngredient>
ParametroTipo
Parametro
minDamage
Tipo
int

Link to onlyDamagedAtMost

Name: onlyDamagedAtMost

Return Type: IngredientConditioned<IIngredient>

ZenScript
Copy
MCItemStackMutable.onlyDamagedAtMost(maxDamage as int) as IngredientConditioned<IIngredient>
ParametroTipo
Parametro
maxDamage
Tipo
int

Name: onlyIf

Return Type: IngredientConditioned<IIngredient>

ZenScript
Copy
MCItemStackMutable.onlyIf(uid as string, function as Predicate<IItemStack>) as IngredientConditioned<IIngredient>
ParametroTipoOptional
Parametro
uid
Tipo
string
Optional
no
Parametro
function
Tipo
Predicate<IItemStack>
Optional

Name: percent

Return Type: Percentaged<IItemStack>

ZenScript
Copy
MCItemStackMutable.percent(percentage as double) as Percentaged<IItemStack>
ParametroTipo
Parametro
percentage
Tipo
double

Link to removeEnchantment

Name: removeEnchantment

Removes the given enchantment from this IItemStack.

Returns: This itemStack if it is mutable, a new one with the enchantment removed otherwise
Return Type: IItemStack

ZenScript
Copy
// MCItemStackMutable.removeEnchantment(enchantment as Enchantment) as IItemStack

myMCItemStackMutable.removeEnchantment(<enchantment:minecraft:riptide>);
ParametroTipoDescrizione
Parametro
enchantment
Tipo
Enchantment
Descrizione
The enchantment to remove.

Link to removeGlobalAttribute

Name: removeGlobalAttribute

Removes all AttributeModifiers that use the given Attribute from this IIngredient.

Attributes removed with this method are removed from ItemStacks that match this IIngredient, regardless of how or when the ItemStack was made, if you want to remove the attribute on a single specific ItemStack (such as a specific Diamond Sword made in a recipe), then you should use IItemStack#withoutAttribute.

This method can only remove default Attributes from an ItemStack, it is still possible that an ItemStack can override it.

ZenScript
Copy
// MCItemStackMutable.removeGlobalAttribute(attribute as Attribute, slotTypes as EquipmentSlot[])

myMCItemStackMutable.removeGlobalAttribute(<attribute:minecraft:generic.attack_damage>, [<constant:minecraft:equipmentslot:chest>]);
ParametroTipoDescrizione
Parametro
attribute
Tipo
Attribute
Descrizione
The attribute to remove.
Parametro
slotTypes
Tipo
EquipmentSlot[]
Descrizione
The slot types to remove it from.

Link to removeGlobalAttributeModifier

Name: removeGlobalAttributeModifier

Removes all AttributeModifiers who's ID is the same as the given uuid from this IIngredient.

ZenScript
Copy
// MCItemStackMutable.removeGlobalAttributeModifier(uuid as invalid, slotTypes as EquipmentSlot[])

myMCItemStackMutable.removeGlobalAttributeModifier(IItemStack.BASE_ATTACK_DAMAGE_UUID, [<constant:minecraft:equipmentslot:chest>]);
ParametroTipoDescrizione
Parametro
uuid
Tipo
invalid
Descrizione
The unique id of the AttributeModifier to remove.
Parametro
slotTypes
Tipo
EquipmentSlot[]
Descrizione
The slot types to remove it from.

Link to removeGlobalAttributeModifier

Name: removeGlobalAttributeModifier

Removes all AttributeModifiers who's ID is the same as the given uuid from this IIngredient.

ZenScript
Copy
// MCItemStackMutable.removeGlobalAttributeModifier(uuid as string, slotTypes as EquipmentSlot[])

myMCItemStackMutable.removeGlobalAttributeModifier("8c1b5535-9f79-448b-87ae-52d81480aaa3", [<constant:minecraft:equipmentslot:chest>]);
ParametroTipoDescrizione
Parametro
uuid
Tipo
string
Descrizione
The unique id of the AttributeModifier to remove.
Parametro
slotTypes
Tipo
EquipmentSlot[]
Descrizione
The slot types to remove it from.

Name: removeTooltip

ZenScript
Copy
MCItemStackMutable.removeTooltip(regex as string)
ParametroTipo
Parametro
regex
Tipo
string

Name: resetHoverName

Clears any custom name set for this ItemStack

ZenScript
Copy
// MCItemStackMutable.resetHoverName()

myMCItemStackMutable.resetHoverName();

Name: reuse

Return Type: IIngredientTransformed<IIngredient>

ZenScript
Copy
// MCItemStackMutable.reuse() as IIngredientTransformed<IIngredient>

myMCItemStackMutable.reuse();

Name: setBurnTime

Sets the burn time of this ingredient, for use in the furnace and other machines

ZenScript
Copy
// MCItemStackMutable.setBurnTime(time as int)

myMCItemStackMutable.setBurnTime(500);
ParametroTipoDescrizione
Parametro
time
Tipo
int
Descrizione
the new burn time

Name: setBurnTime

Sets the burn time of this ingredient, for use in the furnace and other machines

ZenScript
Copy
MCItemStackMutable.setBurnTime(time as int, manager as IRecipeManager)
ParametroTipoDescrizione
Parametro
time
Tipo
int
Descrizione
the new burn time
Parametro
manager
Tipo
IRecipeManager
Descrizione

Name: setEnchantments

Sets the enchantments on this IItemStack.

Returns: This itemStack if it is mutable, a new one with the enchantments otherwise
Return Type: IItemStack

ZenScript
Copy
MCItemStackMutable.setEnchantments(enchantments as int?[Enchantment]) as IItemStack
ParametroTipoDescrizione
Parametro
enchantments
Tipo
int?[Enchantment]
Descrizione
The new enchantments

Link to setFireResistant

Name: setFireResistant

Sets if this IItemStack is immune to fire / lava.

If true, the item will not burn when thrown into fire or lava.

ZenScript
Copy
MCItemStackMutable.setFireResistant(fireResistant as boolean)
ParametroTipoDescrizione
Parametro
fireResistant
Tipo
boolean
Descrizione
Should the item be immune to fire.

Name: setFood

ZenScript
Copy
MCItemStackMutable.setFood(food as FoodProperties?)
ParametroTipo
Parametro
food
Tipo
FoodProperties?

Name: setMaxStackSize

Sets the max stacksize of the Item.

ZenScript
Copy
// MCItemStackMutable.setMaxStackSize(newMaxStackSize as int)

myMCItemStackMutable.setMaxStackSize(16);
ParametroTipoDescrizione
Parametro
newMaxStackSize
Tipo
int
Descrizione
The new max stack size of the Item.

Name: setRarity

Sets the rarity of the Item.

ZenScript
Copy
// MCItemStackMutable.setRarity(newRarity as Rarity)

myMCItemStackMutable.setRarity(Rarity.UNCOMMON);
ParametroTipoDescrizione
Parametro
newRarity
Tipo
Rarity
Descrizione
The new rarity of the Item.

Name: shrink

Shrinks this IItemStack's stack size by the given amount, or 1 if no amount is given.

Returns: This IItemStack if mutable, a new one with the new amount otherwise.
Return Type: IItemStack

ZenScript
Copy
// MCItemStackMutable.shrink(amount as int) as IItemStack

myMCItemStackMutable.shrink(2);
ParametroTipoDescrizioneOptionalDefault Value
Parametro
amount
Tipo
int
Descrizione
The amount to shrink by.
Optional
Default Value
1

Name: transform

Use this if you already have the transformer from another ingredient

Return Type: IIngredientTransformed<IIngredient>

ZenScript
Copy
MCItemStackMutable.transform(transformer as IIngredientTransformer<IIngredient>) as IIngredientTransformed<IIngredient>
ParametroTipo
Parametro
trasformatore
Tipo
IIngredientTransformer<IIngredient>

Name: transformCustom

Return Type: IIngredientTransformed<IIngredient>

ZenScript
Copy
MCItemStackMutable.transformCustom(uid as string, function as Function<IItemStack,IItemStack>) as IIngredientTransformed<IIngredient>
ParametroTipoOptional
Parametro
uid
Tipo
string
Optional
no
Parametro
function
Tipo
Function<IItemStack,IItemStack>
Optional

Name: transformDamage

Return Type: IIngredientTransformed<IIngredient>

ZenScript
Copy
MCItemStackMutable.transformDamage(amount as int) as IIngredientTransformed<IIngredient>
ParametroTipoOptionalDefault Value
Parametro
amount
Tipo
int
Optional
Default Value
1

Link to transformReplace

Name: transformReplace

Return Type: IIngredientTransformed<IIngredient>

ZenScript
Copy
MCItemStackMutable.transformReplace(replaceWith as IItemStack) as IIngredientTransformed<IIngredient>
ParametroTipo
Parametro
replaceWith
Tipo
IItemStack

Link to withAttributeModifier

Name: withAttributeModifier

Adds an AttributeModifier to this IItemStack.

The UUID can be used to override an existing attribute on an ItemStack with this new modifier. You can use /ct hand attributes to get the UUID of the attributes on an ItemStack.

Attributes added with this method will only appear on this specific IItemStack.

By defaults, adding a modifier will remove the default Attribute Modifiers on the Item, like the Diamond Chestplate's Armor and Toughness values. When preserveDefaults is set to true (by default it is false.), the default Attribute Modifiers will be preserved when adding this modifier. This means that if you were adding the forge:nametag_distance attribute to an Item, it would keep its default attributes (like Armor and Toughness values).

Return Type: IItemStack

ZenScript
Copy
// MCItemStackMutable.withAttributeModifier(attribute as Attribute, name as string, value as double, operation as AttributeOperation, slotTypes as EquipmentSlot[], preserveDefaults as boolean) as IItemStack

myMCItemStackMutable.withAttributeModifier(<attribute:minecraft:generic.attack_damage>, "Extra Power", 10, AttributeOperation.ADDITION, [<constant:minecraft:equipmentslot:chest>], true);
ParametroTipoDescrizioneOptionalDefault Value
Parametro
attribute
Tipo
Attribute
Descrizione
The Attribute of the modifier.
Optional
no
Default Value
Parametro
nome
Tipo
string
Descrizione
The name of the modifier.
Optional
no
Default Value
Parametro
valore
Tipo
double
Descrizione
The value of the modifier.
Optional
no
Default Value
Parametro
operation
Tipo
AttributeOperation
Descrizione
The operation of the modifier.
Optional
no
Default Value
Parametro
slotTypes
Tipo
EquipmentSlot[]
Descrizione
What slots the modifier is valid for.
Optional
no
Default Value
Parametro
preserveDefaults
Tipo
boolean
Descrizione
Should the default Item Attribute Modifiers be preserved when adding this modifier.
Optional
Default Value
no

Link to withAttributeModifier

Name: withAttributeModifier

Adds an AttributeModifier to this IItemStack using a specific UUID.

The UUID can be used to override an existing attribute on an ItemStack with this new modifier. You can use /ct hand attributes to get the UUID of the attributes on an ItemStack.

Attributes added with this method will only appear on this specific IItemStack.

By defaults, adding a modifier will remove the default Attribute Modifiers on the Item, like the Diamond Chestplate's Armor and Toughness values. When preserveDefaults is set to true (by default it is false.), the default Attribute Modifiers will be preserved when adding this modifier. This means that if you were adding the forge:nametag_distance attribute to an Item, it would keep its default attributes (like Armor and Toughness values).

Return Type: IItemStack

ZenScript
Copy
// MCItemStackMutable.withAttributeModifier(attribute as Attribute, uuid as invalid, name as string, value as double, operation as AttributeOperation, slotTypes as EquipmentSlot[], preserveDefaults as boolean) as IItemStack

myMCItemStackMutable.withAttributeModifier(<attribute:minecraft:generic.attack_damage>, "8c1b5535-9f79-448b-87ae-52d81480aaa3", "Extra Power", 10, AttributeOperation.ADDITION, [<constant:minecraft:equipmentslot:chest>], true);
ParametroTipoDescrizioneOptionalDefault Value
Parametro
attribute
Tipo
Attribute
Descrizione
The Attribute of the modifier.
Optional
no
Default Value
Parametro
uuid
Tipo
invalid
Descrizione
The unique identifier of the modifier to replace.
Optional
no
Default Value
Parametro
nome
Tipo
string
Descrizione
The name of the modifier.
Optional
no
Default Value
Parametro
valore
Tipo
double
Descrizione
The value of the modifier.
Optional
no
Default Value
Parametro
operation
Tipo
AttributeOperation
Descrizione
The operation of the modifier.
Optional
no
Default Value
Parametro
slotTypes
Tipo
EquipmentSlot[]
Descrizione
What slots the modifier is valid for.
Optional
no
Default Value
Parametro
preserveDefaults
Tipo
boolean
Descrizione
Should the default Item Attribute Modifiers be preserved when adding this modifier.
Optional
Default Value
no

Link to withAttributeModifier

Name: withAttributeModifier

Adds an AttributeModifier to this IItemStack using a specific UUID.

The UUID can be used to override an existing attribute on an ItemStack with this new modifier. You can use /ct hand attributes to get the UUID of the attributes on an ItemStack.

Attributes added with this method will only appear on this specific IItemStack.

By defaults, adding a modifier will remove the default Attribute Modifiers on the Item, like the Diamond Chestplate's Armor and Toughness values. When preserveDefaults is set to true (by default it is false.), the default Attribute Modifiers will be preserved when adding this modifier. This means that if you were adding the forge:nametag_distance attribute to an Item, it would keep its default attributes (like Armor and Toughness values).

Return Type: IItemStack

ZenScript
Copy
// MCItemStackMutable.withAttributeModifier(attribute as Attribute, uuid as string, name as string, value as double, operation as AttributeOperation, slotTypes as EquipmentSlot[], preserveDefaults as boolean) as IItemStack

myMCItemStackMutable.withAttributeModifier(<attribute:minecraft:generic.attack_damage>, "8c1b5535-9f79-448b-87ae-52d81480aaa3", "Extra Power", 10, AttributeOperation.ADDITION, [<constant:minecraft:equipmentslot:chest>], true);
ParametroTipoDescrizioneOptionalDefault Value
Parametro
attribute
Tipo
Attribute
Descrizione
The Attribute of the modifier.
Optional
no
Default Value
Parametro
uuid
Tipo
string
Descrizione
The unique identifier of the modifier to replace.
Optional
no
Default Value
Parametro
nome
Tipo
string
Descrizione
The name of the modifier.
Optional
no
Default Value
Parametro
valore
Tipo
double
Descrizione
The value of the modifier.
Optional
no
Default Value
Parametro
operation
Tipo
AttributeOperation
Descrizione
The operation of the modifier.
Optional
no
Default Value
Parametro
slotTypes
Tipo
EquipmentSlot[]
Descrizione
What slots the modifier is valid for.
Optional
no
Default Value
Parametro
preserveDefaults
Tipo
boolean
Descrizione
Should the default Item Attribute Modifiers be preserved when adding this modifier.
Optional
Default Value
no

Name: withDamage

Sets the damage of the ItemStack

Return Type: IItemStack

ZenScript
Copy
// MCItemStackMutable.withDamage(damage as int) as IItemStack

myMCItemStackMutable.withDamage(10);
ParametroTipoDescrizione
Parametro
damage
Tipo
int
Descrizione
the new damage value

Name: withDisplayName

Sets the display name of the ItemStack

Return Type: IItemStack

ZenScript
Copy
// MCItemStackMutable.withDisplayName(name as Component) as IItemStack

myMCItemStackMutable.withDisplayName("totally not dirt");
ParametroTipoDescrizione
Parametro
nome
Tipo
Component
Descrizione
New name of the stack.

Name: withEnchantment

Enchants this IItemStack with the given Enchantment.

Returns: This itemStack if it is mutable, a new one with the enchantment added otherwise
Return Type: IItemStack

ZenScript
Copy
// MCItemStackMutable.withEnchantment(enchantment as Enchantment, level as int) as IItemStack

myMCItemStackMutable.withEnchantment(<enchantment:minecraft:riptide>, 2);
ParametroTipoDescrizioneOptionalDefault Value
Parametro
enchantment
Tipo
Enchantment
Descrizione
The enchantment to add.
Optional
no
Default Value
Parametro
level
Tipo
int
Descrizione
The level of the enchantment
Optional
Default Value
1

Name: withLore

Sets the lore of the ItemStack

Return Type: IItemStack

ZenScript
Copy
// MCItemStackMutable.withLore(lore as Component?[]) as IItemStack

myMCItemStackMutable.withLore(new crafttweaker.api.text.TextComponent("I am the lore I speak for the trees"););
ParametroTipoDescrizione
Parametro
lore
Tipo
Component?[]
Descrizione
the new Lore of the ItemStack.

Name: withTag

Sets the tag for the ItemStack.

Returns: This itemStack if it is mutable, a new one with the changed property otherwise
Return Type: IItemStack

ZenScript
Copy
// MCItemStackMutable.withTag(tag as MapData) as IItemStack

myMCItemStackMutable.withTag({Display: {lore: ["Hello"]}});
ParametroTipoDescrizione
Parametro
tag
Tipo
MapData
Descrizione
The tag to set.

Name: withoutTag

Removes the tag from this ItemStack.

Returns: This itemStack if it is mutable, a new one with the changed property otherwise
Return Type: IItemStack

ZenScript
Copy
// MCItemStackMutable.withoutTag() as IItemStack

myMCItemStackMutable.withoutTag();

Name: CONTAINS

Does the ingredient contain the given ingredient?

ZenScript
Copy
ingredient as IIngredient in myMCItemStackMutable
(<item:minecraft:iron_ingot> | <item:minecraft:gold_ingot>) in myMCItemStackMutable

Name: EQUALS

ZenScript
Copy
myMCItemStackMutable == o as Object

Name: MOD

ZenScript
Copy
myMCItemStackMutable % percentage as double

Name: MUL

Use this in contexts where machines accept more than one item to state that fact.

ZenScript
Copy
myMCItemStackMutable * amount as int

Name: OR

ZenScript
Copy
myMCItemStackMutable | other as IIngredient
NomeTipoHa GetterHa SetterDescrizione
Nome
amount
Tipo
int
Ha Getter
Ha Setter
no
Descrizione
Gets the amount of Items in the ItemStack
Nome
baseRepairCost
Tipo
int
Ha Getter
Ha Setter
no
Descrizione
Gets the base repair cost of the ItemStack, or 0 if no repair is defined.
Nome
burnTime
Tipo
void
Ha Getter
no
Ha Setter
Descrizione
Sets the burn time of this ingredient, for use in the furnace and other machines
Nome
damage
Tipo
int
Ha Getter
Ha Setter
no
Descrizione
Nome
damageableItem
Tipo
boolean
Ha Getter
Ha Setter
no
Descrizione
Returns if the ItemStack is damageable
I.E Swords and tools are damageable, sticks are not.
Nome
damaged
Tipo
boolean
Ha Getter
Ha Setter
no
Descrizione
Returns if the ItemStack is damaged
I.E a Swords that is no at full durability is damaged.
Nome
definition
Tipo
ItemDefinition
Ha Getter
Ha Setter
no
Descrizione
Nome
descriptionId
Tipo
string
Ha Getter
Ha Setter
no
Descrizione
Returns the unlocalized Name of the Item in the ItemStack
Nome
displayName
Tipo
Component
Ha Getter
Ha Setter
no
Descrizione
Gets the display name of the ItemStack
Nome
enchantments
Tipo
int?[Enchantment]
Ha Getter
Ha Setter
Descrizione
Nome
fireResistant
Tipo
boolean
Ha Getter
Ha Setter
Descrizione
Checks if this IItemStack burns when thrown into fire / lava or damaged by fire.
Nome
food
Tipo
FoodProperties?
Ha Getter
Ha Setter
Descrizione
Nome
hasCustomHoverName
Tipo
boolean
Ha Getter
Ha Setter
no
Descrizione
Returns true if the ItemStack has a display name.
Nome
hasFoil
Tipo
boolean
Ha Getter
Ha Setter
no
Descrizione
Returns true if this ItemStack has a foil effect.

Foil is the glint / effect that is added to enchanted ItemStacks (and other items).
Nome
hasTag
Tipo
boolean
Ha Getter
Ha Setter
no
Descrizione
Returns true if this ItemStack has a Tag
Nome
hoverName
Tipo
Component
Ha Getter
Ha Setter
no
Descrizione
Gets the hover name of the ItemStack.

This will give the raw name without the formatting that 'displayName' applies.
Nome
isEdible
Tipo
boolean
Ha Getter
Ha Setter
no
Descrizione
Nome
isEnchantable
Tipo
boolean
Ha Getter
Ha Setter
no
Descrizione
Can this ItemStack be enchanted?
Nome
isEnchanted
Tipo
boolean
Ha Getter
Ha Setter
no
Descrizione
Is this ItemStack enchanted?
Nome
isMutable
Tipo
boolean
Ha Getter
Ha Setter
no
Descrizione
Nome
maxDamage
Tipo
int
Ha Getter
Ha Setter
Descrizione
Returns the max damage of the ItemStack
This is the max durability of the ItemStack.
Nome
maxStackSize
Tipo
int
Ha Getter
Ha Setter
Descrizione
Returns the max stack size of the Item in the ItemStack
Nome
owner
Tipo
string
Ha Getter
Ha Setter
no
Descrizione
Gets owning mod for the Item in this IItemStack
Nome
rarity
Tipo
Rarity
Ha Getter
Ha Setter
Descrizione
Returns the rarity of the Item in the ItemStack
Nome
registryName
Tipo
ResourceLocation
Ha Getter
Ha Setter
no
Descrizione
Gets the registry name for the Item in this IItemStack
Nome
stackable
Tipo
boolean
Ha Getter
Ha Setter
no
Descrizione
Returns if the ItemStack can have an amount greater than 1
I.E Swords and tools are not stackable, sticks are.
Nome
tag
Tipo
IData?
Ha Getter
Ha Setter
no
Descrizione
Returns the NBT tag attached to this ItemStack.
Nome
useDuration
Tipo
int
Ha Getter
Ha Setter
no
Descrizione
Gets the use duration of the ItemStack
Nome
useOnRelease
Tipo
boolean
Ha Getter
Ha Setter
no
Descrizione
Returns true if this stack is considered a crossbow item