- v50 information can now be added to pages in the main namespace. v0.47 information can still be found in the DF2014 namespace. See here for more details on the new versioning policy.
- Use this page to report any issues related to the migration.
40d:Reactions
This article is about an older version of DF. |
Reactions currently control the actions of the Template:L building. They consist of at least one reagent and one product. Eventually the goal is to include all buildings and their actions within the raws.
You may have multiple reagents and products within a reaction. By including a product that replaces a consumed reagent, you could create things like tools and catalytic reactions.
Additions to reaction_standard.txt do not take effect until you generate a new world, but changes to existing reactions take effect next time you open the game.
Anatomy of a Reaction
[REACTION:BITUMINOUS_COAL_TO_COKE] <-- The name of the reaction. Not referenced elsewhere yet, but must be unique.
NAME
[NAME:make coke from bituminous coal] <-- What appears in the game when the necessary reagents are available.
SMELTER
[SMELTER] <-- Says the reaction is performed in the smelter. There are currently no other building tokens.
REAGENT
Reagents come in three main types.
Type 1
[REAGENT:<Quantity>:<Template:L>:<ITEM_SUBTYPE>:<Template:L>:<MATGLOSS_SUBTYPE>]
As with all raw entries the values here are separated by colons. This style of reaction has five variables.
Quantity
The number of items this reaction requires.
ITEM_TOKEN
A value from the <Template:L> list for the item you want to make.
ITEM_SUBTYPE
An item identifier from the raw file for this item type. For instance if you want to make gloves you would look in the item_gloves.txt file and find the name of one of the items there like ITEM_GLOVES_GLOVES. You would also need to set the ITEM_TOKEN to GLOVES. If you don't have a subtype to use just put "NONE".
MATGLOSS_TOKEN
You put the general category of the material you want to use here.
MATGLOSS_SUBTYPE
The specific type goes here. Like the ITEM_SUBTYPE, you can look up the possible values from the raws. The material COAL has two valid subtypes (COKE and CHARCOAL), and all other materials not defined in the raws should use NO_MATGLOSS.
Type 2
[REAGENT:<Quantity>:REACTION_CLASS:<Class>]
This permits the usage of any stone which contains a matching Template:L token. Normally, the only class used is FLUX to permit any of several types of stone to be used for making pig iron and steel.
Type 3
[REAGENT:<Quantity>:METAL_ORE:<Metal>]
This permits the usage of any stone which contains a matching Template:L token, useful for allowing one reaction to take any type of ore that yields a particular metal.
PRODUCT
[PRODUCT:100:3:BAR:NO_SUBTYPE:COAL:COKE] <-- The end product(s) of the reaction. The first parameter is the percentage of completion for that product. Once it reach 100, one unit of the product will pop up. The second parameter is the amount of objects that will be created. The rest is the same as in REAGENT.
FUEL
[FUEL] <-- Says the reaction uses fuel.
Notes
It is seemingly impossible to use extracts of any sort (liquid, powder, and so on) in smelter reactions. It likely won't show up on the job list at all and, if it does, will result in immediate cancellation when a dwarf tries to select it from the job queue. Extracts can be the product of a reaction but since they must be stored, they will immediately be "spilled" upon creation and be impossible to store and use.