Record Class DifferenceIngredient
java.lang.Object
java.lang.Record
net.neoforged.neoforge.common.crafting.DifferenceIngredient
- All Implemented Interfaces:
ICustomIngredient
public record DifferenceIngredient(Ingredient base, Ingredient subtracted)
extends Record
implements ICustomIngredient
Ingredient that matches everything from the first ingredient that is not included in the second ingredient
-
Field Summary
FieldsModifier and TypeFieldDescriptionprivate final IngredientThe field for thebaserecord component.static final com.mojang.serialization.MapCodec<DifferenceIngredient> private final IngredientThe field for thesubtractedrecord component. -
Constructor Summary
ConstructorsConstructorDescriptionDifferenceIngredient(Ingredient base, Ingredient subtracted) Creates an instance of aDifferenceIngredientrecord class. -
Method Summary
Modifier and TypeMethodDescriptionbase()Returns the value of thebaserecord component.final booleanIndicates whether some other object is "equal to" this one.getItems()Returns the list of stacks that this ingredient accepts.getType()Returns the type of this ingredient.final inthashCode()Returns a hash code value for this object.booleanisSimple()Returns whether this ingredient always requires direct stack testing.static Ingredientof(Ingredient base, Ingredient subtracted) Gets the difference from the two ingredientsReturns the value of thesubtractedrecord component.booleanChecks if a stack matches this ingredient.final StringtoString()Returns a string representation of this record class.Methods inherited from class java.lang.Object
clone, finalize, getClass, notify, notifyAll, wait, wait, waitMethods inherited from interface net.neoforged.neoforge.common.crafting.ICustomIngredient
toVanilla
-
Field Details
-
base
The field for thebaserecord component. -
subtracted
The field for thesubtractedrecord component. -
CODEC
-
-
Constructor Details
-
DifferenceIngredient
Creates an instance of aDifferenceIngredientrecord class.- Parameters:
base- the value for thebaserecord componentsubtracted- the value for thesubtractedrecord component
-
-
Method Details
-
getItems
Description copied from interface:ICustomIngredientReturns the list of stacks that this ingredient accepts.The following guidelines should be followed for good compatibility:
- These stacks are generally used for display purposes, and need not be exhaustive or perfectly accurate.
- An exception is ingredients that are simple,
for which it is important that the returned stacks correspond exactly to all the accepted
Items. - At least one stack must be returned for the ingredient not to be considered accidentally empty.
- The ingredient should try to return at least one stack with each accepted
Item. This allows mods that inspect the ingredient to figure out which stacks it might accept.
Note: no caching needs to be done by the implementation, this is already handled by the ingredient itself.
- Specified by:
getItemsin interfaceICustomIngredient- Returns:
- the list of stacks that this ingredient accepts
-
test
Description copied from interface:ICustomIngredientChecks if a stack matches this ingredient. The stack must not be modified in any way.- Specified by:
testin interfaceICustomIngredient- Parameters:
stack- the stack to test- Returns:
trueif the stack matches this ingredient,falseotherwise
-
isSimple
public boolean isSimple()Description copied from interface:ICustomIngredientReturns whether this ingredient always requires direct stack testing.- Specified by:
isSimplein interfaceICustomIngredient- Returns:
trueif this ingredient ignores NBT data when matching stacks,falseotherwise- See Also:
-
getType
Description copied from interface:ICustomIngredientReturns the type of this ingredient.The type must be registered to
NeoForgeRegistries.INGREDIENT_TYPES.- Specified by:
getTypein interfaceICustomIngredient- Returns:
- the type of this ingredient
-
of
Gets the difference from the two ingredients- Parameters:
base- Ingredient the item must matchsubtracted- Ingredient the item must not match- Returns:
- Ingredient that
baseanything in base that is not insubtracted
-
toString
Returns a string representation of this record class. The representation contains the name of the class, followed by the name and value of each of the record components. -
hashCode
public final int hashCode()Returns a hash code value for this object. The value is derived from the hash code of each of the record components. -
equals
Indicates whether some other object is "equal to" this one. The objects are equal if the other object is of the same class and if all the record components are equal. All components in this record class are compared withObjects::equals(Object,Object). -
base
Returns the value of thebaserecord component.- Returns:
- the value of the
baserecord component
-
subtracted
Returns the value of thesubtractedrecord component.- Returns:
- the value of the
subtractedrecord component
-