Predicates
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:
- The predicate serializer ID.
- Any other fields specific to the predicate serializer.
A predicate object.
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:
- The predicate serializer ID.
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:
mantle:inverted
.
Always - 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.
A predicate object.
And
The “and predicate” matches if all of the nested predicates match. It has the following format:
mantle:and
.
Always - A predicate object. May be any predicate serializer for the desired predicate type.
List of predicates, all must match for the “and predicate” to match.
A predicate object.
Or
The “or predicate” matches if any of the nested predicates match. It has the following format:
mantle:or
.
Always - A predicate object. May be any predicate serializer for the desired predicate type.
List of predicates, if any match the “or predicate” will match.
A predicate object.
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:
mantle:tag
.
Always - ID of a tag in the registry associated with the predicate type.
A predicate object.
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:
mantle:set
.
Always - Block ID option to match.
List of block IDs, matches if any match the input.
A block predicate object.
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:
mantle:block_properties
.
Always - Block to match. All block properties must come from the passed block.
<name>
is the given string value.
Property will exactly match when <name>
is any value within the list.<name>
.
Option for
Property will match if <name>
is within the passed range of values.<name>
. If unset, property matches with no minimum value.
Minimum value for <name>
. If unset, property matches with no maximum value.
Maximum value for
Property will match if
Map of property name to expected value. Matching behavior varies based on the type of the values:
A block predicate object.
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:
mantle:set
.
Always - Item ID option to match.
List of item IDs, matches if any match the input.
A item predicate object.
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:
mantle:set
.
Always - Entity ID option to match.
List of entity IDs, matches if any match the input.
A entity predicate object.
Has Enchantment
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:
mantle:has_enchantment
.
Always - ID of an enchantment to check for on the entity’s equipment.
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:
mantle:has_enchantment
.
Always 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.
ID of the mob type to check. By default, the following options are available:
A entity predicate object.
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 arenull
.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:
mantle:attacker
.
Always - entity predicate serializer ID matching the attacker. An
- All relevant fields from the entity predicate serializer.
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
Selects which entity to check. Options:
A damage predicate object.
Message
The message damage predicate matches a specific damage source based on the damage source message field. It has the following format:
mantle:message
.
Always - the Minecraft Wiki, and typically match the translation key for the death message without the prefix
death.attack.
or suffix.player
.
Damage source message ID to match. Message IDs are listed on
A damage predicate object.
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:
tconstruct:single
.
Always - Modifier ID to match.
A modifier predicate object.
Slot Type
The slot type modifier predicate matches modifiers that have a recipe costing the given slot type. It has the following format:
tconstruct:slot_type
.
Always null
, matches modifiers that have a recipe charging no slots (slotless).
Modifier must have a recipe charging the given slot type to match. If unset or
A modifier predicate object.
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:
tconstruct:has_modifier
.
Always - Predicate matching the modifier expected on the tool.
- 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.
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.
Modifier list to check, may be one of the following:
A tool context predicate object.
Has Material
The has material tool context predicate matches tools that contain the given material. It has the following format:
tconstruct:has_material
.
Always - Material variant expected on the tool.
- Index expected to contain the tool material. If unset, will check the entire material list.
A tool context predicate object.
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:
tconstruct:has_stat_type
.
Always - Stat type that must be used by the tool.
- If set, the stat type must contain the passed material variant.
- Index expected to contain the tool material. If unset, will check the entire material list.
A tool context predicate object.
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:
tconstruct:stat_in_range
.
Always - Numeric tool stat to match.
- Minimum allowed value. If unset, there is no minimum.
- Maximum allowed value. If unset, there is no maximum.
A tool context predicate object.
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:
tconstruct:stat_in_set
.
Always - Tool stat to match.
- Allowed stat value. JSON type varies based on the tool stat.
List of allowed values for the stat.
A tool context predicate object.