Record Class EnchantmentItemAdvancedIngredient

java.lang.Object
java.lang.Record
com.petrolpark.core.recipe.ingredient.advanced.EnchantmentItemAdvancedIngredient
All Implemented Interfaces:
IAdvancedIngredient<net.minecraft.world.item.ItemStack>, IForcingItemAdvancedIngredient, ItemAdvancedIngredient, ITypelessAdvancedIngredient<net.minecraft.world.item.ItemStack>, Predicate<net.minecraft.world.item.ItemStack>

public record EnchantmentItemAdvancedIngredient(net.minecraft.advancements.critereon.EnchantmentPredicate enchantments) extends Record implements ItemAdvancedIngredient
  • Field Details

    • CODEC

      public static final com.mojang.serialization.MapCodec<EnchantmentItemAdvancedIngredient> CODEC
    • STREAM_CODEC

      public static final net.minecraft.network.codec.StreamCodec<net.minecraft.network.RegistryFriendlyByteBuf,EnchantmentItemAdvancedIngredient> STREAM_CODEC
    • RANDOM

      public static final net.minecraft.util.RandomSource RANDOM
  • Constructor Details

    • EnchantmentItemAdvancedIngredient

      public EnchantmentItemAdvancedIngredient(net.minecraft.advancements.critereon.EnchantmentPredicate enchantments)
      Creates an instance of a EnchantmentItemAdvancedIngredient record class.
      Parameters:
      enchantments - the value for the enchantments record component
  • Method Details

    • test

      public boolean test(net.minecraft.world.item.ItemStack stack)
      Specified by:
      test in interface ItemAdvancedIngredient
      Specified by:
      test in interface Predicate<net.minecraft.world.item.ItemStack>
    • modifyExamples

      @Nullable public Stream<net.minecraft.world.item.ItemStack> modifyExamples(Stream<net.minecraft.world.item.ItemStack> exampleStacks)
      Description copied from interface: ITypelessAdvancedIngredient
      Modify an example stack so it fulfill this IAdvancedIngredient.
      Specified by:
      modifyExamples in interface ITypelessAdvancedIngredient<net.minecraft.world.item.ItemStack>
      Parameters:
      exampleStacks - May be modified
      Returns:
      A stack fulfilling this Ingredient, possibly the same object reference, or null if that stack can never fulfill this Ingredient
    • modifyCounterExamples

      @Nullable public Stream<net.minecraft.world.item.ItemStack> modifyCounterExamples(Stream<net.minecraft.world.item.ItemStack> counterExampleStacks)
      Description copied from interface: ITypelessAdvancedIngredient
      Modify an example stack so it does not fulfill this IAdvancedIngredient.
      Specified by:
      modifyCounterExamples in interface ITypelessAdvancedIngredient<net.minecraft.world.item.ItemStack>
      Parameters:
      counterExampleStacks - May be modified
      Returns:
      A stack not fulfilling this Ingredient, possibly the same object reference, or null if that stack always fulfills this Ingredient
    • forceLootItemFunction

      @Nonnull public Optional<net.minecraft.world.item.ItemStack> forceLootItemFunction(net.minecraft.world.level.storage.loot.functions.LootItemFunction function, net.minecraft.world.level.storage.loot.LootContext context, net.minecraft.world.item.ItemStack stack)
      Description copied from interface: IForcingItemAdvancedIngredient
      Attempt to force the output of the given LootItemFunction to conform to this IAdvancedIngredient. This should not return an ItemStack which could not have been generated by the LootItemFunction naturally. It is not guaranteed that the returned ItemStack (if there is one) will conform, but this method should make a best effort.
      Specified by:
      forceLootItemFunction in interface IForcingItemAdvancedIngredient
      Specified by:
      forceLootItemFunction in interface ItemAdvancedIngredient
      Parameters:
      function - The LootItemFunction being called. This will never be a SequenceFunction, as those are unpacked automatically. Also, if it is a LootItemConditionalFunction, then it will have already passed all conditions by the time this method is called.
      context -
      stack - The ItemStack to which the LootItemFunction is being applied
      Returns:
      Non-null Optional, filled if an ItemStack could be generated matching this IAdvancedIngredient, or empty if we could not force the output of the LootItemFunction successfully and it should be called as normal.
    • forbidLootItemFunction

      @Nonnull public Optional<net.minecraft.world.item.ItemStack> forbidLootItemFunction(net.minecraft.world.level.storage.loot.functions.LootItemFunction function, net.minecraft.world.level.storage.loot.LootContext context, net.minecraft.world.item.ItemStack stack)
      Description copied from interface: IForcingItemAdvancedIngredient
      Attempt to force the output of the given LootItemFunction so it does not conform to this IAdvancedIngredient. This should not return an ItemStack which could not have been generated by the LootItemFunction naturally. It is not guaranteed that the returned ItemStack (if there is one) won't conform, but this method should make a best effort.
      Specified by:
      forbidLootItemFunction in interface IForcingItemAdvancedIngredient
      Specified by:
      forbidLootItemFunction in interface ItemAdvancedIngredient
      Parameters:
      function - The LootItemFunction being called. This will never be a SequenceFunction, as those are unpacked automatically. Also, if it is a LootItemConditionalFunction, then it will have already passed all conditions by the time this method is called.
      context -
      stack - The ItemStack to which the LootItemFunction is being applied
      Returns:
      Non-null Optional, filled if an ItemStack could be generated not matching this IAdvancedIngredient, or empty if we could not force the output of the LootItemFunction successfully and it should be called as normal.
    • forceTradeListing

      @Nullable public Optional<net.minecraft.world.item.trading.MerchantOffer> forceTradeListing(net.minecraft.world.entity.npc.VillagerTrades.ItemListing tradeListing, net.minecraft.world.entity.Entity trader, net.minecraft.util.RandomSource random)
      Description copied from interface: IForcingItemAdvancedIngredient
      Attempt to force the output of the given VillagerTrades.ItemListing to a MerchantOffer whose output conforms to this IAdvancedIngredient. This should not generate a MerchantOffer which could not have been generated by the VillagerTrades.ItemListing naturally. It is not guaranteed that the result of the returned MerchantOffer (if there is one) will conform, but this method should make a best effort.
      Specified by:
      forceTradeListing in interface IForcingItemAdvancedIngredient
      Specified by:
      forceTradeListing in interface ItemAdvancedIngredient
      Parameters:
      tradeListing -
      trader -
      random -
      Returns:
      null if this IAdvancedIngredient could not generate a MerchantOffer with a matching result, an empty Optional if the VillagerTrades.ItemListing should generate no MerchantOffer at all (i.e. return null), or a filled Optional containing a MerchantOffer with a matching result.
    • forbidTradeListing

      @Nullable public Optional<net.minecraft.world.item.trading.MerchantOffer> forbidTradeListing(net.minecraft.world.entity.npc.VillagerTrades.ItemListing tradeListing, net.minecraft.world.entity.Entity trader, net.minecraft.util.RandomSource random)
      Description copied from interface: IForcingItemAdvancedIngredient
      Attempt to force the output of the given VillagerTrades.ItemListing to a MerchantOffer whose output does not conform to this IAdvancedIngredient. This should not generate a MerchantOffer which could not have been generated by the VillagerTrades.ItemListing naturally. It is not guaranteed that the result of the returned MerchantOffer (if there is one) won't conform, but this method should make a best effort.
      Specified by:
      forbidTradeListing in interface IForcingItemAdvancedIngredient
      Specified by:
      forbidTradeListing in interface ItemAdvancedIngredient
      Parameters:
      tradeListing -
      trader -
      random -
      Returns:
      null if this IAdvancedIngredient could not generate a MerchantOffer with a non-matching result, an empty Optional if the VillagerTrades.ItemListing should generate no MerchantOffer at all (i.e. return null), or a filled Optional containing a MerchantOffer with a non-matching result.
    • addToDescription

      public void addToDescription(Lang.IndentedTooltipBuilder description)
      Specified by:
      addToDescription in interface ITypelessAdvancedIngredient<net.minecraft.world.item.ItemStack>
    • addToCounterDescription

      public void addToCounterDescription(Lang.IndentedTooltipBuilder description)
      Specified by:
      addToCounterDescription in interface ITypelessAdvancedIngredient<net.minecraft.world.item.ItemStack>
    • addToDescriptionInternal

      protected void addToDescriptionInternal(Lang.IndentedTooltipBuilder description, String postfix)
    • getType

      public INamedAdvancedIngredientType<net.minecraft.world.item.ItemStack> getType()
      Specified by:
      getType in interface IAdvancedIngredient<net.minecraft.world.item.ItemStack>
      Specified by:
      getType in interface ItemAdvancedIngredient
    • allEnchantments

      protected static final Supplier<Stream<net.minecraft.core.Holder<net.minecraft.world.item.enchantment.Enchantment>>> allEnchantments(net.minecraft.world.level.storage.loot.LootContext context)
    • getEnchantments

      protected static final net.minecraft.world.item.enchantment.ItemEnchantments getEnchantments(net.minecraft.world.item.ItemStack stack)
    • toString

      public final String 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.
      Specified by:
      toString in class Record
      Returns:
      a string representation of this object
    • 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.
      Specified by:
      hashCode in class Record
      Returns:
      a hash code value for this object
    • equals

      public final boolean equals(Object o)
      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 with Objects::equals(Object,Object).
      Specified by:
      equals in class Record
      Parameters:
      o - the object with which to compare
      Returns:
      true if this object is the same as the o argument; false otherwise.
    • enchantments

      public net.minecraft.advancements.critereon.EnchantmentPredicate enchantments()
      Returns the value of the enchantments record component.
      Returns:
      the value of the enchantments record component