If you need to reference this type directly, like when casting an Array, or as a parameter, you will need to import it. Simply add the import at
the top of the file.
import crafttweaker . api.ingredient.type . IIngredientEmpty;
IIngredientEmpty
implements the following interfaces:
IIngredient
,CommandStringDisplayable
Undocumented Interfaces Comparable <Enum >
IIngredientEmpty is an enum with 1 constant. It is accessible like so:
IIngredientEmpty . INSTANCE
Does the ingredient contain the given ingredient? // ((ingredient as IIngredient) in IIngredientEmpty) as bool
myIIngredient in IIngredientEmpty . INSTANCE
Return Type:
bool
Use this in contexts where machines accept more than one item to state that fact. // (IIngredientEmpty * (amount as int)) as IIngredientWithAmount
IIngredientEmpty . INSTANCE * myInt
Return Type:
IIngredientWithAmount
// (IIngredientEmpty | (other as IIngredient)) as IIngredientList
IIngredientEmpty . INSTANCE | myIIngredient
Return Type:
IIngredientList
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 // IIngredientEmpty.addGlobalAttributeModifier(attribute as Attribute, name as string, value as double, operation as Operation, slotTypes as EquipmentSlot[]);
IIngredientEmpty . INSTANCE . addGlobalAttributeModifier( < attribute : minecraft:generic.attack_damage > , "Extra Power" , 10 , AttributeOperation . ADDITION, [ < constant : minecraft:equipmentslot:chest > ]);
Parameters:
name: string
Type: string
- The name of the modifier.
value: double
Type: double
- The value of the modifier.
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 // IIngredientEmpty.addGlobalAttributeModifier(attribute as Attribute, uuid as string, name as string, value as double, operation as Operation, slotTypes as EquipmentSlot[]);
IIngredientEmpty . INSTANCE . addGlobalAttributeModifier( < attribute : minecraft:generic.attack_damage > , "8c1b5535-9f79-448b-87ae-52d81480aaa3" , "Extra Power" , 10 , AttributeOperation . ADDITION, [ < constant : minecraft:equipmentslot:chest > ]);
Parameters:
uuid: string
Type: string
- The unique identifier of the modifier to replace.
name: string
Type: string
- The name of the modifier.
value: double
Type: double
- The value of the modifier.
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 // IIngredientEmpty.addGlobalAttributeModifier(attribute as Attribute, uuid as UUID, name as string, value as double, operation as Operation, slotTypes as EquipmentSlot[]);
IIngredientEmpty . INSTANCE . addGlobalAttributeModifier( < attribute : minecraft:generic.attack_damage > , IItemStack . BASE_ATTACK_DAMAGE_UUID, "Extra Power" , 10 , AttributeOperation . ADDITION, [ < constant : minecraft:equipmentslot:chest > ]);
Parameters:
uuid: UUID
Type: UUID
- The unique identifier of the modifier to replace.
name: string
Type: string
- The name of the modifier.
value: double
Type: double
- The value of the modifier.
// IIngredientEmpty.addShiftTooltip(content as Component, showMessage as Component = null);
IIngredientEmpty . INSTANCE . addShiftTooltip(myComponent, myComponent);
// IIngredientEmpty.addTooltip(content as Component);
IIngredientEmpty . INSTANCE . addTooltip(myComponent);
// IIngredientEmpty as IData
IIngredientEmpty . INSTANCE as IData
Return Type:
IData
Used implicitly when a machine can accept more than one item but you only provide one. // IIngredientEmpty.asIIngredientWithAmount() as IIngredientWithAmount;
IIngredientEmpty . INSTANCE . asIIngredientWithAmount();
Return Type:
IIngredientWithAmount
Used implicitly when a machine can accept more than one item but you only provide one. // IIngredientEmpty as IIngredientWithAmount
IIngredientEmpty . INSTANCE as IIngredientWithAmount
Return Type:
IIngredientWithAmount
// IIngredientEmpty as MapData
IIngredientEmpty . INSTANCE as MapData
Return Type:
MapData
Sets the burn time of this ingredient, for use in the furnace and other machines // IIngredientEmpty.burnTime = (time as int);
IIngredientEmpty . INSTANCE . burnTime = myInt;
Parameters:
time: int
Type: int
- the new burn time
Sets the burn time of this ingredient, for use in the furnace and other machines // IIngredientEmpty.burnTime(time as int);
IIngredientEmpty . INSTANCE . burnTime( 500 );
Parameters:
time: int
Type: int
- the new burn time
// IIngredientEmpty.clearTooltip(leaveName as bool = false);
IIngredientEmpty . INSTANCE . clearTooltip(myBool);
Parameters:
leaveName: bool
(optional) Type: bool
Default Value: false
Does the ingredient contain the given ingredient? // IIngredientEmpty.contains(ingredient as IIngredient) as bool;
IIngredientEmpty . INSTANCE . contains(( < item : minecraft:iron_ingot > | < item : minecraft:gold_ingot > ));
Return Type:
bool
// IIngredientEmpty.getInstance() as IIngredientEmpty;
IIngredientEmpty . getInstance();
Return Type:
IIngredientEmpty
When this ingredient stack is crafted, what will remain in the grid? Does not check if the stack matches though! Used e.g. in Crafting Table recipes. // IIngredientEmpty.getRemainingItem(stack as IItemStack) as IItemStack;
IIngredientEmpty . INSTANCE . getRemainingItem( < item : minecraft:iron_ingot > );
Return Type:
IItemStack
Does the given stack match the ingredient? // IIngredientEmpty.matches(stack as IItemStack) as bool;
IIngredientEmpty . INSTANCE . matches( < item : minecraft:iron_ingot > );
Return Type:
bool
// IIngredientEmpty.modifyShiftTooltip(shiftedFunction as ITooltipFunction, unshiftedFunction as ITooltipFunction = null);
IIngredientEmpty . INSTANCE . modifyShiftTooltip(myITooltipFunction, myITooltipFunction);
// IIngredientEmpty.modifyTooltip(function as ITooltipFunction);
IIngredientEmpty . INSTANCE . modifyTooltip(myITooltipFunction);
Use this in contexts where machines accept more than one item to state that fact. // IIngredientEmpty.mul(amount as int) as IIngredientWithAmount;
IIngredientEmpty . INSTANCE . mul(myInt);
Return Type:
IIngredientWithAmount
Use this if you already have the condition from another ingredient // IIngredientEmpty.only(condition as IIngredientCondition<IIngredient>) as IIngredientConditioned<IIngredient>;
IIngredientEmpty . INSTANCE . only(myIIngredientCondition);
Return Type:
IngredientConditioned <IIngredient >
// IIngredientEmpty.onlyDamaged() as IIngredientConditioned<IIngredient>;
IIngredientEmpty . INSTANCE . onlyDamaged();
Return Type:
IngredientConditioned <IIngredient >
// IIngredientEmpty.onlyDamagedAtLeast(minDamage as int) as IIngredientConditioned<IIngredient>;
IIngredientEmpty . INSTANCE . onlyDamagedAtLeast(myInt);
Return Type:
IngredientConditioned <IIngredient >
// IIngredientEmpty.onlyDamagedAtMost(maxDamage as int) as IIngredientConditioned<IIngredient>;
IIngredientEmpty . INSTANCE . onlyDamagedAtMost(myInt);
Return Type:
IngredientConditioned <IIngredient >
// IIngredientEmpty.onlyIf(uid as string, function as function(t as IItemStack) as bool = null) as IIngredientConditioned<IIngredient>;
IIngredientEmpty . INSTANCE . onlyIf(myString, myPredicate);
Parameters:
uid: string
Type: string
function: function(t as IItemStack ) as bool
(optional) Type: function(t as IItemStack ) as bool
Default Value: null
Return Type:
IngredientConditioned <IIngredient >
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. // IIngredientEmpty.removeGlobalAttribute(attribute as Attribute, slotTypes as EquipmentSlot[]);
IIngredientEmpty . INSTANCE . removeGlobalAttribute( < attribute : minecraft:generic.attack_damage > , [ < constant : minecraft:equipmentslot:chest > ]);
Removes all AttributeModifiers who's ID is the same as the given uuid from this IIngredient. // IIngredientEmpty.removeGlobalAttributeModifier(uuid as string, slotTypes as EquipmentSlot[]);
IIngredientEmpty . INSTANCE . removeGlobalAttributeModifier( "8c1b5535-9f79-448b-87ae-52d81480aaa3" , [ < constant : minecraft:equipmentslot:chest > ]);
Parameters:
uuid: string
Type: string
- The unique id of the AttributeModifier to remove.
Removes all AttributeModifiers who's ID is the same as the given uuid from this IIngredient. // IIngredientEmpty.removeGlobalAttributeModifier(uuid as UUID, slotTypes as EquipmentSlot[]);
IIngredientEmpty . INSTANCE . removeGlobalAttributeModifier( IItemStack . BASE_ATTACK_DAMAGE_UUID, [ < constant : minecraft:equipmentslot:chest > ]);
Parameters:
uuid: UUID
Type: UUID
- The unique id of the AttributeModifier to remove.
// IIngredientEmpty.removeTooltip(regex as string);
IIngredientEmpty . INSTANCE . removeTooltip(myString);
Parameters:
regex: string
Type: string
Use this if you already have the transformer from another ingredient // IIngredientEmpty.transform(transformer as IIngredientTransformer<IIngredient>) as IIngredientTransformed<IIngredient>;
IIngredientEmpty . INSTANCE . transform(myIIngredientTransformer);
Return Type:
IIngredientTransformed <IIngredient >
// IIngredientEmpty.transformCustom(uid as string, function as function(r as IItemStack) as IItemStack = null) as IIngredientTransformed<IIngredient>;
IIngredientEmpty . INSTANCE . transformCustom(myString, myFunction);
Return Type:
IIngredientTransformed <IIngredient >
// IIngredientEmpty.transformDamage(amount as int = 1) as IIngredientTransformed<IIngredient>;
IIngredientEmpty . INSTANCE . transformDamage(myInt);
Parameters:
amount: int
(optional) Type: int
Default Value: 1
Return Type:
IIngredientTransformed <IIngredient >
// IIngredientEmpty.transformReplace(replaceWith as IItemStack) as IIngredientTransformed<IIngredient>;
IIngredientEmpty . INSTANCE . transformReplace(myIItemStack);
Return Type:
IIngredientTransformed <IIngredient >