Record Class CompoundAdvancedIngredient<STACK>

java.lang.Object
java.lang.Record
com.petrolpark.core.recipe.ingredient.advanced.CompoundAdvancedIngredient<STACK>
All Implemented Interfaces:
IForcingItemAdvancedIngredient, ITypelessAdvancedIngredient<STACK>, Predicate<STACK>

public record CompoundAdvancedIngredient<STACK>(List<IAdvancedIngredient<? super STACK>> ingredients, int required) extends Record implements ITypelessAdvancedIngredient<STACK>, IForcingItemAdvancedIngredient
  • Constructor Details

    • CompoundAdvancedIngredient

      public CompoundAdvancedIngredient(List<IAdvancedIngredient<? super STACK>> ingredients, int required)
      Creates an instance of a CompoundAdvancedIngredient record class.
      Parameters:
      ingredients - the value for the ingredients record component
      required - the value for the required record component
  • Method Details

    • codec

      public static final <STACK> com.mojang.serialization.MapCodec<CompoundAdvancedIngredient<STACK>> codec(com.mojang.serialization.Codec<IAdvancedIngredient<? super STACK>> typeCodec)
    • streamCodec

      public static final <STACK> net.minecraft.network.codec.StreamCodec<net.minecraft.network.RegistryFriendlyByteBuf,CompoundAdvancedIngredient<STACK>> streamCodec(net.minecraft.network.codec.StreamCodec<net.minecraft.network.RegistryFriendlyByteBuf,IAdvancedIngredient<? super STACK>> typeStreamCodec)
    • typelessAnd

      protected static final <STACK> CompoundAdvancedIngredient<STACK> typelessAnd(List<IAdvancedIngredient<? super STACK>> ingredients)
    • typelessOr

      protected static final <STACK> CompoundAdvancedIngredient<STACK> typelessOr(List<IAdvancedIngredient<? super STACK>> ingredients)
    • and

      public static final IAdvancedIngredient<net.minecraft.world.item.ItemStack> and(List<IAdvancedIngredient<? super net.minecraft.world.item.ItemStack>> ingredients)
    • or

      public static final IAdvancedIngredient<net.minecraft.world.item.ItemStack> or(List<IAdvancedIngredient<? super net.minecraft.world.item.ItemStack>> ingredients)
    • test

      public boolean test(STACK stack)
      Specified by:
      test in interface Predicate<STACK>
    • streamExamples

      public Stream<? extends STACK> streamExamples()
      Description copied from interface: ITypelessAdvancedIngredient
      All (or an exemplary subset) of the stacks which fulfill this IAdvancedIngredient. This is not guaranteed to have every possible stack, and should never be used that way.
      Specified by:
      streamExamples in interface ITypelessAdvancedIngredient<STACK>
      Returns:
      Non-null, potentially empty Stream
    • streamCounterExamples

      public Stream<? extends STACK> streamCounterExamples()
      Description copied from interface: ITypelessAdvancedIngredient
      All (or an exemplary subset) of the stacks which do not fulfill this IAdvancedIngredient. This is not guaranteed to have every possible stack (and in fact will usually be empty), and should never be used that way.
      Specified by:
      streamCounterExamples in interface ITypelessAdvancedIngredient<STACK>
      Returns:
      Non-null, potentially empty Stream
    • modifyExamples

      public Stream<STACK> modifyExamples(Stream<STACK> exampleStacks)
      Description copied from interface: ITypelessAdvancedIngredient
      Modify an example stack so it fulfill this IAdvancedIngredient.
      Specified by:
      modifyExamples in interface ITypelessAdvancedIngredient<STACK>
      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
    • modifyExamples

      protected <STACK_PARENT> Stream<STACK> modifyExamples(Stream<STACK> exampleStacks, IAdvancedIngredient<STACK_PARENT> ingredient)
    • modifyCounterExamples

      public Stream<STACK> modifyCounterExamples(Stream<STACK> counterExampleStacks)
      Description copied from interface: ITypelessAdvancedIngredient
      Modify an example stack so it does not fulfill this IAdvancedIngredient.
      Specified by:
      modifyCounterExamples in interface ITypelessAdvancedIngredient<STACK>
      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
    • modifyCounterExamples

      protected <STACK_PARENT> Stream<STACK> modifyCounterExamples(Stream<STACK> exampleStacks, IAdvancedIngredient<STACK_PARENT> ingredient)
    • addToDescription

      public void addToDescription(Lang.IndentedTooltipBuilder description)
      Specified by:
      addToDescription in interface ITypelessAdvancedIngredient<STACK>
    • addToCounterDescription

      public void addToCounterDescription(Lang.IndentedTooltipBuilder description)
      Specified by:
      addToCounterDescription in interface ITypelessAdvancedIngredient<STACK>
    • 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
      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
      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
      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
      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.
    • simplify

      public ITypelessAdvancedIngredient<? super STACK> simplify()
      Description copied from interface: ITypelessAdvancedIngredient
      The IAdvancedIngredient (not necessarily of the same type) which is the exact same predicate as this, but which has the smallest possible overhead. It is acceptable to mutate this Ingredient while calling this method, so careful caching the unsimplified version. Usually this will just return this.
      Specified by:
      simplify in interface ITypelessAdvancedIngredient<STACK>
    • isImpossible

      public boolean isImpossible()
    • isOr

      public boolean isOr()
    • isAnd

      public boolean isAnd()
    • cast

      protected Optional<CompoundAdvancedIngredient<? super STACK>> cast(IAdvancedIngredient<? super STACK> ingredient)
    • translate

      protected net.minecraft.network.chat.Component translate(String keyPostfix, Object... args)
    • 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. Reference components are compared with Objects::equals(Object,Object); primitive components are compared with '=='.
      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.
    • ingredients

      public List<IAdvancedIngredient<? super STACK>> ingredients()
      Returns the value of the ingredients record component.
      Returns:
      the value of the ingredients record component
    • required

      public int required()
      Returns the value of the required record component.
      Returns:
      the value of the required record component