Adding Support to other Mods
As long as a mod’s recipes use the vanilla IRecipe Datapack system, and therefore work with IRecipeManagers, then you are able to add new recipes regardless of if the mod has native support or not. This is still a bit tricky, but doable nonetheless. There are a couple steps to doing this:
The first one is finding the recipetype we want to add a recipe to. This should be done using /ct dump recipetypes
. Once you’ve got it, you should find a .json
recipe that belongs to that recipetype in the mods source. Only can generally be found under the datagen path of the mod, which generally is: src/main/resources/data/recipetype/recipes
in the mods source and data/modid/recipes
in the mod’s jar. The path might change depending on the mod though.
In any case, once you have your example recipe, you can start adding things following the JSON structure. An example from CharcoalPit2 looks like this:
That is pure JSON, and you need to translate that recipe into something that crafttweaker can work with. Depending on the mod each key might be named differently, and support for tags and amounts is something that changes depending on the mod.
This works, but it takes up a lot of space, so we are going to write a custom function that will handle most of our use cases. Remember that recipe names need to be unique!
Some functionality (like output nbt) might require a more complex function that checks if there is nbt in the item, or adding support for tags. But this covers the most simple use case which largely reduces script size and doesn’t fill it with JSON recipes, which are sometimes tedious to write too. Pretty neat huh?