130 lines
6.1 KiB
ReStructuredText
130 lines
6.1 KiB
ReStructuredText
labormanager
|
|
============
|
|
|
|
.. dfhack-tool::
|
|
:summary: Automatically manage dwarf labors.
|
|
:tags: fort auto labors
|
|
|
|
Labormanager is derived from `autolabor` but uses a completely different
|
|
approach to assigning jobs to dwarves. While autolabor tries to keep as many
|
|
dwarves busy as possible, labormanager instead strives to get jobs done as
|
|
quickly as possible.
|
|
|
|
Labormanager frequently scans the current job list, current list of dwarves, and
|
|
the map to determine how many dwarves need to be assigned to what labors in
|
|
order to meet all current labor needs without starving any particular type of
|
|
job.
|
|
|
|
Dwarves on active military duty or dwarves assigned to burrows are left
|
|
untouched.
|
|
|
|
.. warning::
|
|
|
|
As with autolabor, labormanager will override any manual changes you make to
|
|
labors while it is enabled, including through other tools such as Dwarf
|
|
Therapist. Do not run both autolabor and labormanager at the same time!
|
|
|
|
Usage::
|
|
|
|
enable labormanager
|
|
|
|
Anything beyond this is optional - labormanager works well with the default
|
|
settings. Once you have enabled it in a fortress, it stays enabled until you
|
|
explicitly disable it, even if you save and reload your game.
|
|
|
|
The default priorities for each labor vary (some labors are higher priority by
|
|
default than others). The way the plugin works is that, once it determines how
|
|
many jobs of each labor is needed, it then sorts them by adjusted priority.
|
|
(Labors other than hauling have a bias added to them based on how long it's been
|
|
since they were last used to prevent job starvation.) The labor with the highest
|
|
priority is selected, the "best fit" dwarf for that labor is assigned to that
|
|
labor, and then its priority is *halved*. This process is repeated until either
|
|
dwarves or labors run out.
|
|
|
|
Because there is no easy way to detect how many haulers are actually needed at
|
|
any moment, the plugin always ensures that at least one dwarf is assigned to
|
|
each of the hauling labors, even if no hauling jobs are detected. At least one
|
|
dwarf is always assigned to construction removing and cleaning because these
|
|
jobs also cannot be easily detected. Lever pulling is always assigned to
|
|
everyone. Any dwarves for which there are no jobs will be assigned hauling,
|
|
lever pulling, and cleaning labors. If you use animal trainers, note that
|
|
labormanager will misbehave if you assign specific trainers to specific animals;
|
|
results are only guaranteed if you use "any trainer".
|
|
|
|
Labormanager also sometimes assigns extra labors to currently busy dwarfs so
|
|
that when they finish their current job, they will go off and do something
|
|
useful instead of standing around waiting for a job.
|
|
|
|
There is special handling to ensure that at least one dwarf is assigned to haul
|
|
food whenever food is detected left in a place where it will rot if not stored.
|
|
This will cause a dwarf to go idle if you have no stockpiles to haul food to.
|
|
|
|
Dwarves who are unable to work (child, in the military, wounded, handless,
|
|
asleep, in a meeting) are entirely excluded from labor assignment. Any dwarf
|
|
explicitly assigned to a burrow will also be completely ignored by labormanager.
|
|
|
|
The fitness algorithm for assigning jobs to dwarves generally attempts to favor
|
|
dwarves who are more skilled over those who are less skilled. It also tries to
|
|
avoid assigning female dwarfs with children to jobs that are "outside", favors
|
|
assigning "outside" jobs to dwarfs who are carrying a tool that could be used as
|
|
a weapon, and tries to minimize how often dwarves have to reequip.
|
|
|
|
Labormanager automatically determines medical needs and reserves health care
|
|
providers as needed. Note that this may cause idling if you have injured dwarves
|
|
but no or inadequate hospital facilities.
|
|
|
|
Hunting is never assigned without a butchery, and fishing is never assigned
|
|
without a fishery, and neither of these labors is assigned unless specifically
|
|
enabled (see below).
|
|
|
|
The method by which labormanager determines what labor is needed for a
|
|
particular job is complicated and, in places, incomplete. In some situations,
|
|
labormanager will detect that it cannot determine what labor is required. It
|
|
will, by default, pause and print an error message on the dfhack console,
|
|
followed by the message "LABORMANAGER: Game paused so you can investigate the
|
|
above message.". If this happens, please open an :issue:`<issue>` on GitHub,
|
|
reporting the lines that immediately preceded this message. You can tell
|
|
labormanager to ignore this error and carry on by running
|
|
``labormanager pause-on-error no``, but be warned that some job may go undone in
|
|
this situation.
|
|
|
|
Examples
|
|
--------
|
|
|
|
``labormanager priority BREWER 500``
|
|
Boost the priority of brewing jobs.
|
|
``labormanager max FISH 1``
|
|
Only assign fishing to one dwarf at a time. Note that you also have to run
|
|
``labormanager allow-fishing`` for any dwarves to be assigned fishing at
|
|
all.
|
|
|
|
Advanced usage
|
|
--------------
|
|
|
|
``labormanager list``
|
|
Show current priorities and current allocation stats. Use this command to
|
|
see the IDs for all labors.
|
|
``labormanager status``
|
|
Show basic status information.
|
|
``labormanager priority <labor> <value>``
|
|
Set the priority value for labor <labor> to <value>.
|
|
``labormanager max <labor> <value>``
|
|
Set maximum number of dwarves that can be assigned to a labor.
|
|
``labormanager max <labor> none``
|
|
Unrestrict the number of dwarves that can be assigned to a labor.
|
|
``labormanager max <labor> disable``
|
|
Don't manage the specified labor. Dwarves who you have manually enabled this
|
|
labor on will be less likely to have managed labors assigned to them.
|
|
``labormanager reset-all|reset <labor>``
|
|
Return a labor (or all labors) to the default priority.
|
|
``labormanager allow-fishing|forbid-fishing``
|
|
Allow/disallow fisherdwarves. *Warning* Allowing fishing tends to result in
|
|
most of the fort going fishing. Fishing is forbidden by default.
|
|
``labormanager allow-hunting|forbid-hunting``
|
|
Allow/disallow hunterdwarves. *Warning* Allowing hunting tends to result in
|
|
as many dwarves going hunting as you have crossbows. Hunting is forbidden by
|
|
default.
|
|
``labormanager pause-on-error yes|no``
|
|
Make labormanager pause/continue if the labor inference engine fails. See
|
|
the above section for details.
|