This page is about conditions that cannot list

Predicates are used in many different JSON formats to represent a condition that must be matched by a piece of the JSON format. Unlike ingredients, predicates are not required to list their full contents for display in recipe viewers, though they may be used indirectly to construct displays.

Predicates are defined in Mantle, and support many different vanilla registries. In addition, mods such as Tinkers’ Construct define additional predicate types.

Format

A predicate may be defined either in compact format or in object format.

In object format, a predicate is defined as follows:

  • (Object): A predicate object.
    • type (Resource Location): The predicate serializer ID.
    • Any other fields specific to the predicate serializer.

If a predicate has no additional fields, or all the additional fields are using the default value, it may be defined compactly using just a string containing the predicate serializer ID as follows:

Common Predicates

All predicates support the predicate serializers defined in the following subsections. Whenever a predicate references another predicate serializer, any predicate serializer for the given type may be used.

Any

The any predicate matches everything. It has a predicate type ID of mantle:any and no additional fields.

Inverted

The inverted predicate matches anything not matched by the nested predicate. It has the following format:

  • (Object): A predicate object.
    • type (Resource Location): Always mantle:inverted.
    • inverted_type (Resource Location): The predicate serializer ID to invert. If that predicate would return true, the inverted predicate returns false.
    • Any other fields specific to the inverted predicate serializer.

And

The “and predicate” matches if all of the nested predicates match. It has the following format:

  • (Object): A predicate object.
    • type (Resource Location): Always mantle:and.
    • predicates (Array): List of predicates, all must match for the “and predicate” to match.
      • (predicate): A predicate object. May be any predicate serializer for the desired predicate type.

Or

The “or predicate” matches if any of the nested predicates match. It has the following format:

  • (Object): A predicate object.
    • type (Resource Location): Always mantle:or.
    • predicates (Array): List of predicates, if any match the “or predicate” will match.
      • (predicate): A predicate object. May be any predicate serializer for the desired predicate type.

Tag

Some predicate types, most notably those defined from vanilla registries, support tag predicates. The tag predicate will match if the input is in the given tag. Unlike other common predicate serializers, not every predicate type supports tag predicates.

Tag predicates have the following format:

  • (Object): A predicate object.
    • type (Resource Location): Always mantle:tag.
    • tag (Tag): ID of a tag in the registry associated with the predicate type.

Block Predicates

Block predicates match block state values. They support all common predicate serializers (including tag predicates), along with the following serializers which have no extra fields:

  • mantle:requires_tool: Matches any block which requires mining with the correct tool to drop items from it’s loot table.

In addition, the following sections discuss serializers with additional fields.

In 1.18, some uses of block predicates used a version defined by Tinkers’ Construct where all common predicate along with the required_tool predicate were registered under a domain of tconstruct instead of mantle.

Block Set

The block set predicate matches if the block is within the given set. Block set predicates are effectively a hardcoded block tag predicate, useful when a set is not reusable enough to need a specific tag.

Block set predicates have the following format:

  • (Object): A block predicate object.
    • type (Resource Location): Always mantle:set.
    • blocks (Array): List of block IDs, matches if any match the input.

In 1.18, some uses of the block predicate used a version defined by Tinkers’ Construct. For those block predicates, the block set predicate had a type of tconstruct:set.

Block Properties

The block properties predicate matches a given block state on a list of block properties. It has the following format:

  • (Object): A block predicate object.
    • type (Resource Location): Always mantle:block_properties.
    • block (Block ID): Block to match. All block properties must come from the passed block.
    • properties (Object): Map of property name to expected value. Matching behavior varies based on the type of the values:
      • <name> (String): Property will exactly match when <name> is the given string value.
      • <name> (Array): Property will match if <name> is any value within the list.
        • (String): Option for <name>.
      • <name> (Object): Property will match if <name> is within the passed range of values.
        • min (String): Minimum value for <name>. If unset, property matches with no minimum value.
        • max (String): Maximum value for <name>. If unset, property matches with no maximum value.

Item Predicates

Item predicates match item values (notably not item stacks, meaning no count or NBT). They are used in some contexts where items are present but not item stacks, preventing usage of standard item ingredients. Item predicates support all common predicate (including tag predicates), plus the serializers discussed in the following subsections.

Item Set

The item set predicate matches if the item is within the given set. Item set predicates are effectively a hardcoded item tag predicate, useful when a set is not reusable enough to need a specific tag.

Item set predicates have the following format:

  • (Object): A item predicate object.
    • type (Resource Location): Always mantle:set.
    • items (Array): List of item IDs, matches if any match the input.
      • (Item ID): Item ID option to match.

Entity Predicates

Entity predicates match living entity instances, allowing matching properties of active entities in the world. They support all common predicate serializers (including tag predicates), along with the following serializers which have no extra fields:

  • mantle:fire_immune: Matches any entity that is immune to fire damage.
  • mantle:water_sensitive: Matches any entity that takes damage from water.
  • mantle:on_fire: Matches any entity that is on fire.
  • mantle:on_ground: Matches any entity that is currently on the ground.
  • mantle:crouching: Matches any entity that is actively sneaking.
  • mantle:eyes_in_water: Matches any entity which has it’s head underwater.
  • mantle:feet_in_water: Matches any entity that has it’s feet in water.
  • mantle:underwater: Matches any entity that with both it’s head and feet underwater.
  • mantle:raining_at: Matches if it’s raining and the entity has line of sight to the sky in a biome that supports rain.
  • tconstruct:airborne: Matches any entity that is not on the ground, not on a climbable block, not swimming, and not riding another entity.

In addition, the following sections discuss entity predicate serializers with additional fields.

In 1.18, some uses of entity predicates used a legacy version defined by Tinkers’ Construct where all relevant predicates were registered under a domain of tconstruct instead of mantle. In addition, mantle:on_ground, mantle:underwater, and mantle:has_enchantment are not available.

Entity Set

The entity set predicate matches if the entity is within the given set. Entity set predicates are effectively a hardcoded entity tag predicate, useful when a set is not reusable enough to need a specific tag.

Entity set predicates have the following format:

  • (Object): A entity predicate object.
    • type (Resource Location): Always mantle:set.
    • entities (Array): List of entity IDs, matches if any match the input.

Has Enchantment

Not available in legacy Tinkers' Construct entity predicate.

The “has enchantment” entity predicate matches any entity that is wearing a piece of equipment with the given enchantment. This predicate only considers equipment slots that are normally allowed to contain the given enchantment, meaning armor enchantments will only consider armor slots for instance.

The has enchantment entity predicate has the following format:

  • (Object): A entity predicate object.

Mob Type

The mob type entity predicate matches any entity with an entity type belonging to the given mob type.

The has enchantment entity predicate has the following format:

  • (Object): A entity predicate object.
    • type (Resource Location): Always mantle:has_enchantment.
    • mobs (Resource Location): ID of the mob type to check. By default, the following options are available:
      • minecraft:arthropod: Any entities that are considered “arthropod”, notably used by the bane of arthropods enchantment.
      • minecraft:illager: Any entities that are considered “illagers”, used for alliances among illager mobs.
      • minecraft:undead: Entities that are considered “undead”, taking damage from healing potions and the smite enchantment, plus healing from harming potions.
      • minecraft:water: Any entities that typically live underwater.
      • minecraft:undefined: Any entities that don’t belong to another type.

Damage Predicates

Damage predicates match damage source instances, allowing matching based on the cause of damage. They support all common predicate serializers, though notably only support tag predicates in 1.20 and onwards. In addition, they support the following serializers which have no extra fields:

  • mantle:can_protect: Matches damage that is blocked by protection enchantments, specifically damage that does not bypass magic, enchantments, or invulnerability.
  • mantle:is_indirect: Matches damage where the causing entity (e.g. a player or mob) is not the same as the direct entity (if it matches, typically a projectile). Note this will not match if both entities are null.
  • mantle:has_entity: Matches damage sources that have an entity set.
  • tconstruct:direct (since 1.20): Matches damage sources that have an entity, are not indirect, and are not thorns.

In addition, until 1.19.2 the following serializers with no extra fields exist. They were removed in 1.20 due to damage source reworks.

  • mantle:bypass_armor: Matches damage that is not reduced by armor, such as starving, fall damage, fire, and magic.
  • mantle:bypass_enchantments: Matches damage that bypasses protection enchantments, such as the warden’s “sonic boom” attack.
  • mantle:bypass_magic: Matches damage that bypasses magical protections such as protection enchantments or the resistance effect. Notably includes starving damage.
  • mantle:bypass_invulnerable: Matches damage that hurts players in creative, such as void damage.
  • mantle:damage_helmet: Matches damage that causes helmet durability loss, such as falling blocks.
  • mantle:explosion: Matches damage caused by explosions, such as TNT or end crystals.
  • mantle:fall: Matches damage caused by falling, including stalagmites.
  • mantle:fire: Matches damage caused by fire or lava.
  • mantle:magic: Matches damage caused by magic such as potions.
  • mantle:projectile: Matches damage caused by projectiles, such as arrows.
  • mantle:melee: Matches damage that is caused by a melee attack. Unlike other predicates, “melee damage” is not a vanilla concept, so it uses the following heuristics:
    • If the damage is caused by a projectile, it is not melee damage.
    • If the damage is caused by an entity, it is melee damage provided it is it not caused by thorns.
    • If the damage is not caused by an entity, it is melee damage if it does not bypass armor, it is not fire, it is not magic, and it is not an explosion.

In addition, the following sections discuss damage predicate serializers with additional fields.

Attacker

The attacker damage predicate matches damage sources with an attacker matching the specified entity predicate. It fails to match if the source is not caused by a living entity. It has the following format:

  • (Object): A damage predicate object.
    • type (Resource Location): Always mantle:attacker.
    • entity_type (Resource Location): An entity predicate serializer ID matching the attacker.
    • All relevant fields from the entity predicate serializer.
    • which (Resource Location, since 1.20): Selects which entity to check. Options:
      • causing: Checks the entity who initiated the action, typically a player or mob.
      • direct: Checks the entity that directly inflicted the damage. If not a player, will be a mob

Message

The message damage predicate matches a specific damage source based on the damage source message field. It has the following format:

  • (Object): A damage predicate object.
    • type (Resource Location): Always mantle:message.
    • message (String): Damage source message ID to match. Message IDs are listed on the Minecraft Wiki, and typically match the translation key for the death message without the prefix death.attack. or suffix .player.

Modifier Predicates

Modifier predicates are a predicate type added by Tinkers’ Construct, matching modifiers. They support all common predicate serializers, though tag predicates are registered with a type of tconstruct:tag instead of mantle:tag. Additional modifier predicate serializers are discussed in the following sections.

In 1.18, all common predicate were registered under a domain of tconstruct instead of mantle.

Single Modifier

The single modifier predicate matches the given modifier by ID. It has the following format:

Slot Type

The slot type modifier predicate matches modifiers that have a recipe costing the given slot type. It has the following format:

  • (Object): A modifier predicate object.
    • type (Resource Location): Always tconstruct:slot_type.
    • slot (Slot Type): Modifier must have a recipe charging the given slot type to match. If unset or null, matches modifiers that have a recipe charging no slots (slotless).

Tool Predicates

Tool predicates are a predicate type added by Tinkers’ Construct, matching tool instances. There are two variants of tool predicates: tool stack predicates, which are used in most contexts, and tool context predicates, which are used during tool building when tools have more limited data (notably lacking access to tool durability). Both types of predicate support all common predicate serializers, along with item tag predicates matching the tool item.

Tool predicates support fallback behavior; if a predicate serializer ID does not exist in the tool stack registry, it will fallback to a tool context predicate serializer with that ID. If a predicate serializer ID does not exist in the tool context predicate registry, it will fallback to the item predicate registry.

Tool context predicates support the following serializers which have no extra fields:

  • tconstruct:has_upgrades: Matches any tools which have at least 1 modifier added via recipes.

Tool stack predicates support the following serializers which have no extra fields:

  • tconstruct:not_broken: Matches tools which are not broken.

In addition, the following sections discuss tool predicate serializers with additional fields.

Has Modifier

The has modifier tool context predicate matches tools that contain the given modifier. It has the following format:

  • (Object): A tool context predicate object.
    • type (Resource Location): Always tconstruct:has_modifier.
    • modifier (Modifier Predicate): Predicate matching the modifier expected on the tool.
    • level (Integer Range): Range of expected levels of the modifier on the tool. Minimum level is 0, indicating the tool lacks the given modifier. If unset, defaults to 1 or more, indicating the tool has the modifier at any level.
    • check (String): Modifier list to check, may be one of the following:
      • upgrades: Checks the list of modifiers applied using recipes.
      • all: Checks the full list of modifiers on the tool, which includes modifiers from recipes and traits.

Has Material

The has material tool context predicate matches tools that contain the given material. It has the following format:

  • (Object): A tool context predicate object.
    • type (Resource Location): Always tconstruct:has_material.
    • material (Material Variant): Material variant expected on the tool.
    • index (Integer): Index expected to contain the tool material. If unset, will check the entire material list.

Has Stat Type

The has stat type tool context predicate matches tools that require a particular stat type for one of their tool parts. It has the following format:

  • (Object): A tool context predicate object.
    • type (Resource Location): Always tconstruct:has_stat_type.
    • stat_type (Stat Type): Stat type that must be used by the tool.
    • material (Material Variant): If set, the stat type must contain the passed material variant.
    • index (Integer): Index expected to contain the tool material. If unset, will check the entire material list.

Stat in Range

The stat in range tool stack predicate matches tools that have a given numeric tool stat with a value within the passed range. It has the following format:

  • (Object): A tool context predicate object.
    • type (Resource Location): Always tconstruct:stat_in_range.
    • stat (Tool Stat): Numeric tool stat to match.
    • min (Number): Minimum allowed value. If unset, there is no minimum.
    • max (Number): Maximum allowed value. If unset, there is no maximum.

Stat in Set

The stat in set tool stack predicate matches tools that have a given tool stat within the set of values. It has the following format:

  • (Object): A tool context predicate object.
    • type (Resource Location): Always tconstruct:stat_in_set.
    • stat (Tool Stat): Tool stat to match.
    • values (Array): List of allowed values for the stat.
      • (Any): Allowed stat value. JSON type varies based on the tool stat.