Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

[add-recipe] reinstate #854

Merged
merged 1 commit into from
Oct 7, 2023
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
29 changes: 1 addition & 28 deletions add-recipe.lua
Original file line number Diff line number Diff line change
@@ -1,25 +1,4 @@
-- Script to add unknown crafting recipes to the player's civ.
--[====[
add-recipe
==========
Adds unknown weapon and armor crafting recipes to your civ.
E.g. some civilizations never learn to craft high boots. This script can
help with that, and more. Only weapons, armor, and tools are currently supported;
things such as instruments are not. Available options:

* ``add-recipe all`` adds *all* available weapons and armor, including exotic items
like blowguns, two-handed swords, and capes.

* ``add-recipe native`` adds only native (but unknown) crafting recipes. Civilizations
pick randomly from a pool of possible recipes, which means not all civs get
high boots, for instance. This command gives you all the recipes your
civilisation could have gotten.

* ``add-recipe single <item token>`` adds a single item by the given
item token. For example::

add-recipe single SHOES:ITEM_SHOES_BOOTS
]====]

local itemDefs = df.global.world.raws.itemdefs
local resources = df.historical_entity.find(df.global.plotinfo.civ_id).resources
Expand Down Expand Up @@ -125,7 +104,6 @@ function addItems(category, exotic)
return added
end


function printItems(itemList)
for _, v in ipairs(itemList) do
local v = v --as:df.itemdef_weaponst
Expand Down Expand Up @@ -192,10 +170,5 @@ elseif (cmd == "native") then
elseif (cmd == "single") then
addSingleItem(args[2])
else
print("Available options:\n"
.."all: adds all supported crafting recipes.\n"
.."native: adds only unknown native recipes (eg. high boots for "
.."some dwarves)\n"
.."single: adds a specific item by itemstring (eg. "
.."SHOES:ITEM_SHOES_BOOTS)")
print(dfhack.script_help())
end
1 change: 1 addition & 0 deletions changelog.txt
Original file line number Diff line number Diff line change
Expand Up @@ -27,6 +27,7 @@ Template for new versions:
# Future

## New Tools
- `add-recipe`: (reinstated) add reactions to your civ (e.g. for high boots if your civ didn't start with the ability to make high boots)

## New Features

Expand Down
23 changes: 13 additions & 10 deletions docs/add-recipe.rst
Original file line number Diff line number Diff line change
Expand Up @@ -3,26 +3,29 @@ add-recipe

.. dfhack-tool::
:summary: Add crafting recipes to a civ.
:tags: unavailable adventure fort gameplay
:tags: adventure fort gameplay

Civilizations pick randomly from a pool of possible recipes, which means not all
civs get high boots, for instance. This script can help fix that. Only weapons,
armor, and tools are currently supported; things such as instruments are not.
Civilizations pick randomly from a pool of possible recipes, which means, for
example, not all civs get high boots. This script can help fix that. Only
weapons, armor, and tools are currently supported; dynamically generated item
types like instruments are not.

Usage
-----

::

add-recipe (all|native)
add-recipe single <item token>

Examples
--------

``add-recipe native``
Add all crafting recipes that your civ could have chosen from its pool, but
did not.
``add-recipe all``
Add *all* available weapons and armor, including exotic items like
blowguns, two-handed swords, and capes.
``add-recipe single <item token>``
Add a single item by the given item token.

Example
-------

``add-recipe single SHOES:ITEM_SHOES_BOOTS``
Allow your civ to craft high boots.