Processor list
A processor list is used to transform blocks of a structure template during generation. They contain a list of processors. Processor lists are configured using JSON files stored within a data pack in the folder data/<namespace>/worldgen/processor_list.
JSON format
A processor list can be a list, or an object that contains a list.
A list:
- [NBT List / JSON Array]: A list of processors.
- [NBT Compound / JSON Object]: A processor object (see below)
Or an object:
- [NBT Compound / JSON Object]: An object of processor list.
- [NBT List / JSON Array] processors: A list of processors.
- [NBT Compound / JSON Object]: A processor object (see below)
- [NBT List / JSON Array] processors: A list of processors.
Processors
rule
Replaces blocks with custom rules
- [NBT Compound / JSON Object]: A processor object
- [String] processor_type:
minecraft:rule - [NBT List / JSON Array] rules: (Required, but can be empty) A list of rules. Only the first rule that all conditions are met takes effect. This is decided anew for each block.
- [NBT Compound / JSON Object]: A rule.
- [NBT Compound / JSON Object] position_predicate: (Optional, defaults to an "always_true" test) A § Position rule test to apply to the distance from the structure start to this block.
- [NBT Compound / JSON Object] input_predicate: A § Rule test to apply to the block placed by the structure.
- [NBT Compound / JSON Object] location_predicate: A § Rule test to apply to the block in the world that is replaced by the structure.
- [NBT Compound / JSON Object] output_state: The block that is placed when all conditions are met. Omitting block states use default values (e.g. the replacement of stairs with stairs without changing states need 40 rules to check for all facing combinations).
- Block state see Template:Nbt inherit/block state/template
- [NBT Compound / JSON Object] block_entity_modifier: (optional) Modifies nbt data of the block entity if all conditions are met.
- [String] type: Can be
minecraft:append_loot(AppendsLootTablefield andLootTableSeedfield to the block entity. TheLootTableSeeduses a random number seeded by the block position.),minecraft:append_static(Merges specified data into the block entity.),minecraft:clear(Resets any existing fields on the block entity.) orminecraft:passthrough(Do nothing).- If
typeisminecraft:append_loot, additional field is as follows:
- If
- [String] loot_table: The resource location of a loot table.
- If
typeisminecraft:append_static, additional field is as follows:
- If
- [NBT Compound / JSON Object] data: The nbt data to be merged into the block entity. Needs to be in JSON form, see NBT format#JSON and NBT.
- [String] type: Can be
- [NBT Compound / JSON Object]: A rule.
- [String] processor_type:
block_rot
Randomly removes blocks. The removed blocks are not replaced by air, but keep the old blocks before the structure being generated
- [NBT Compound / JSON Object]: A processor object
- [String] processor_type:
minecraft:block_rot - [Float] integrity: The probability of randomly removing blocks in the structure. Value between 0 and 1.
- [String][NBT List / JSON Array] rottable_blocks: (optional) Blocks that can be removed. A block ID or a block tag, or a list of block IDs.
- [String] processor_type:
block_age
Makes blocks aged. A stone, stone bricks, or cracked stone bricks block has a chance of 0.5 to be replaced with one of cracked stone bricks, stone brick stairs, mossy stone bricks, and mossy stone brick stairs. All variants of stairs have a 0.5 chance to become one of stone slab, stone brick slab, mossy stone brick stairs, and mossy stone brick slab. All variants of slabs and walls may remain unchanged or become mossy stone brick variants. Obsidian also has a 0.15 chance to be replaced with crying obsidian.
- [NBT Compound / JSON Object]: A processor object
- [String] processor_type:
minecraft:block_age - [Float] mossiness: Values below 0.0 is treated as 0.0; values above 1.0 is treated as 1.0. The probability of using mossy variants when making a block aged.
- [String] processor_type:
block_ignore
Removes specified blocks. The removed blocks are not replaced by air, but keep the old blocks before the structure being generated.
- [NBT Compound / JSON Object]: A processor object
- [String] processor_type:
minecraft:block_ignore - [NBT List / JSON Array] blocks: (Required, but can be empty) IDs of blocks to ignore. Specifying block states has no effect.
- [NBT Compound / JSON Object]: A block.
- Block state see Template:Nbt inherit/block state/template
- [NBT Compound / JSON Object]: A block.
- [String] processor_type:
gravity
Change the Y-level of blocks' positions to fit the terrain like a village road. Note that this is not used to make floating gravity blocks fall down. This processor is hardcoded to be used on a structure template if its "projection" field in its template pool is "terrain_matching"
- [NBT Compound / JSON Object]: A processor object
- [String] processor_type:
minecraft:gravity - [String] heightmap: (optional, defaults to WORLD_SURFACE_WG) Must be one of
"WORLD_SURFACE_WG"(if not during world generation, fallbacks toWORLD_SURFACE),"WORLD_SURFACE","OCEAN_FLOOR_WG"(if not during world generation, fallbacks toOCEAN_FLOOR),"OCEAN_FLOOR","MOTION_BLOCKING", or"MOTION_BLOCKING_NO_LEAVES". - [Int] offset: (optional, defaults to 0) The offset relative to the terrain. For example: 0 is to place the structure on the ground, -1 is to sink one block into the ground. When this processor is used on a structure template by hardcoding (when the template's "projection" field in its template pool is "terrain_matching"), [Int] offset is -1.
- [String] processor_type:
protected_blocks
Specifies which blocks in the world cannot be overridden by this structure
- [NBT Compound / JSON Object]: A processor object
- [String] processor_type:
minecraft:protected_blocks - [String] value: A block tag with
#.
- [String] processor_type:
blackstone_replace
Replaces all stone-variant blocks with blackstone variants and all iron bars with chains.
- [NBT Compound / JSON Object]: A processor object
- [String] processor_type:
minecraft:blackstone_replace
- [String] processor_type:
jigsaw_replacement
Replaces jigsaw blocks with the specified final state. This processor is hardcoded to be used unless generated in the jigsaw block GUI.
- [NBT Compound / JSON Object]: A processor object
- [String] processor_type:
minecraft:jigsaw_replacement
- [String] processor_type:
lava_submerged_block
Blocks with incomplete outline shapes cannot override the lava in the world
- [NBT Compound / JSON Object]: A processor object
- [String] processor_type:
minecraft:lava_submerged_block
- [String] processor_type:
capped
Applies a processor to some random blocks instead of applying it to all blocks.
- [NBT Compound / JSON Object]: A processor object
- [String] processor_type:
minecraft:capped - [Int][NBT Compound / JSON Object] value: The number of blocks on which the processor is applied. Must be greater than 0. If it is greater than or equal to the total number of blocks in the structure template, all blocks are processed as if the processer is not capped.
- Int provider see Template:Nbt inherit/int_provider/template
- [NBT Compound / JSON Object] delegate: Another processor object
- [String] processor_type:
nop
Does nothing
- [NBT Compound / JSON Object]: A processor object
- [String] processor_type:
minecraft:nop
- [String] processor_type:
Rule test
Rule tests are used to test if a block matches specific conditions.
always_true
Matches any block
- [NBT Compound / JSON Object]: a rule test
- [String] predicate_type:
always_true
- [String] predicate_type:
block_match
Tests is the block is the specified block.
- [NBT Compound / JSON Object]: a rule test
- [String] predicate_type:
block_match - [String] block: A block ID.
- [String] predicate_type:
blockstate_match
Tests is the block for the specified block state.
- [NBT Compound / JSON Object]: a rule test
- [String] predicate_type:
blockstate_match - [NBT Compound / JSON Object] block_state: A block state.
- Block state see Template:Nbt inherit/block state/template
- [String] predicate_type:
random_block_match
Tests is the block is the specified block. Then only matches with a given probability.
- [NBT Compound / JSON Object]: a rule test
- [String] predicate_type:
random_block_match - [String] block: A block ID.
- [Float] probability: The probability of the predicate to pass if the block is found. Values below 0.0 is treated as 0.0; values above 1.0 is treated as 1.0.
- [String] predicate_type:
random_blockstate_match
Tests is the block for the specified block state. Then only matches with a given probability.
- [NBT Compound / JSON Object]: a rule test
- [String] predicate_type:
random_blockstate_match - [NBT Compound / JSON Object] block_state: A block state.
- Block state see Template:Nbt inherit/block state/template
- [Float] probability: The probability of the predicate to pass if the block state is found. Values below 0.0 is treated as 0.0; values above 1.0 is treated as 1.0.
- [String] predicate_type:
tag_match
Tests if the block is in the specified block tag.
- [NBT Compound / JSON Object]: a rule test
- [String] predicate_type:
tag_match - [String] tag: A block tag without
#.
- [String] predicate_type:
Position rule test
Position rule tests are used to test if a position matches specific conditions.
always_true
Matches any position.
- [NBT Compound / JSON Object]: a position rule test
- [String] predicate_type:
always_true
- [String] predicate_type:
linear_pos
Passes with a random probability, the probability is based on the 3D Manhattan distance to the structure start.
- [NBT Compound / JSON Object]: a position rule test
- [String] predicate_type:
linear_pos - [Float] min_chance: (optional, default is 0.0) The probability (probability less than 0 is treated as 0, greater than 1 is treated as 1) for the predicate to pass when the distance of a block to the structure start is equal to or less than
min_dist. - [Float] max_chance: (optional, default is 0.0) The probability (probability less than 0 is treated as 0, greater than 1 is treated as 1) for the predicate to pass when the distance of a block to the structure start is equal to or greater than
max_dist. If a block's distance is betweenmin_distandmax_dist, probability is obtained by linear interpolation between the values ofmin_distandmax_dist, that is, the probability is(distance - min_dist ) / ( max_dist - min_dist ) * ( max_chance - min_chance ) + min_chance, and probability less than 0 is treated as 0, greater than 1 is treated as 1. - [Int] min_dist: (optional, defaults to 0) the distance when the minimum probability is used. Must be less than [Int] max_dist.
- [Int] max_dist: (optional, defaults to 0) the distance when the maximum probability is used. Must be greater than [Int] min_dist.
- [String] predicate_type:
axis_aligned_linear_pos
Passes with a random probability, the probability is based on the distance to the structure start along the specified axis.
- [NBT Compound / JSON Object]: a position rule test
- [String] predicate_type:
axis_aligned_linear_pos - [String] axis: (optional, defaults to
y) can bex,yorz. - [Float] min_chance: (optional, default is 0.0) The probability (probability less than 0 is treated as 0, greater than 1 is treated as 1) for the predicate to pass when the distance of a block to the structure start is equal to or less than
min_dist. - [Float] max_chance: (optional, default is 0.0) The probability (probability less than 0 is treated as 0, greater than 1 is treated as 1) for the predicate to pass when the distance of a block to the structure start is equal to or greater than
max_dist. If a block's distance is betweenmin_distandmax_dist, probability is obtained by linear interpolation between the values ofmin_distandmax_dist, that is, the probability is(distance - min_dist ) / ( max_dist - min_dist ) * ( max_chance - min_chance ) + min_chance, and probability less than 0 is treated as 0, greater than 1 is treated as 1. - [Int] min_dist: (optional, defaults to 0) the distance when the minimum probability is used. Must be less than [Int] max_dist.
- [Int] max_dist: (optional, defaults to 0) the distance when the maximum probability is used. Must be greater than [Int] min_dist.
- [String] predicate_type:
External links
| |||||||||||||||||||||||||||||||
|
| |||||||||||||||||||||||||||||||
| |||||||||||||||||||||||||||||||