Releases: DFHack/dfhack
DFHack 50.09-r3rc3
Q: How do I download DFHack?
A: Either add to your Steam library from our Steam page or scroll to the latest release on our GitHub releases page, expand the "Assets" list, and download the file for your platform (e.g. dfhack-XX.XX-rX-Windows-64bit.zip
.
This beta is compatible with DF 50.09 for Windows (Dwarf Fortress Steam default branch, Itch, and Classic) and DF 50.09-linux1 for Linux (Dwarf Fortress beta branch). It does not support the Windows version of DF deployed on the DF beta branch (which is currently nearly identical to the Windows version on the default branch).
Announcements
Linux Support, PSAs
Linux support!
Both DF and DFHack now run natively on Linux. If you're on Linux, we encourage you to try it! The interface is noticeably snappier, FPS is up, and load times are reduced. If you're subscribed to DF and DFHack on Steam, here's how to switch over:
- In the Steam client, open the properties for Dwarf Fortress
- In the "Betas" section, switch to the "beta" branch
- Let that finish updating
- Select the "Compatibility" section and deselect "Force the use of a specific Steam Play compatibility tool"
- DF should update again with the Linux native version
You can tell if you did it right if you no longer have Dwarf Fortress.exe
in your DF directory and instead have dwarfort
, which is the Linux binary. The plan is to "officially" release Linux support with DF 50.10, so once DF 50.10 comes out, you should be able to switch back to the default Steam branch and keep the native Linux support.
Then, do the same thing for DFHack. switching to the "beta" branch (if you're not there already) and turning off the compatibility layer.
Sometimes, Steam says you've got the Linux version, but when you look you see you still have Dwarf Fortress.exe
instead of dwarfort
. Try re-enabling the Proton compatibility layer and then turning off the compatibility layer again.
Major caveat for this beta release
This particular beta release of Dwarf Fortress has address layout randomization enabled. This causes some trouble for DFHack since DFHack needs to know the memory addresses of several key data structures. For this release only, be sure to start DF by launching DFHack from the Steam client or by running the ./dfhack
commandline startup script. That will normalize the address space and allow DF to run with DFHack. Otherwise, DF will crash on startup. Again, this is only for this release. Future releases will not need this workaround and should go back to allowing you to start DF from either the Dwarf Fortress or DFHack Steam client entries, or from either the ./dwarfort
or ./dfhack
commandline commands.
The DFHack terminal console works differently on Linux
You can run DF with DFHack by starting DFHack in the Steam client. However, if you want an external DFHack terminal console, you have to run from the commandline.
On Windows, you could use the show
command to pop up an external DFHack terminal console. You could use this for running DFHack commands from outside the game window, and the external terminal is the only way to run commandline-interactive DFHack commands like tiletypes
and the interactive mode of the lua
interpreter.
Linux has a different method of providing a terminal console. You can't spawn it dynamically like you can on Windows. You have to start DF from the commandline, and the terminal from which you ran ./dwarfort
becomes the terminal console. This should be a familiar process to many Linux users (most Linux commands work this way), but the change is jarring if you're not expecting it. We're also looking into providing a virtual console that doesn't depend on an existing system console so you can still get a console even if you run from Steam, but that work is far from being completed.
You can still launch DFHack from Steam if you want to. Many tools log information and errors to the console, though, so if you run into strange issues, it might be useful to try running from the commandline to see if there is diagnostic output there that can help you.
PSAs
As always, remember that, just like the vanilla DF game, DFHack tools can also have bugs. It is a good idea to save often and keep backups of the forts that you care about.
Many DFHack tools that worked in previous (pre-Steam) versions of DF have not been updated yet and are marked with the "unavailable" tag in their docs. If you try to run them, they will show a warning and exit immediately. You can run the command again to override the warning (though of course the tools may not work). We make no guarantees of reliability for the tools that are marked as "unavailable".
The in-game interface for running DFHack commands (gui/launcher
) will not show "unavailable" tools by default. You can still run them if you know their names, or you can turn on dev mode by hitting Ctrl-D while in gui/launcher
and they will be added to the autocomplete list. Some tools do not compile yet and are not available at all, even when in dev mode.
If you see a tool complaining about the lack of a cursor, know that it's referring to the keyboard cursor (which used to be the only real option in Dwarf Fortress). You can enable the keyboard cursor by entering mining mode or selecting the dump/forbid tool and hitting Alt-K (the DFHack keybinding for toggle-kbd-cursor
. We're working on making DFHack tools more mouse-aware and accessible so this step isn't necessary in the future.
Highlights
Hide tutorial popups, See inside bins when selecting trade goods, Updated squad selection screen
Hide tutorial popups
Once you've played a few forts, you probably don't need the tutorial popups that assault you when you open certain screens. Enable hide-tutorials
in the System tab of gui/control-panel
and never be bothered by them again!
See inside bins when selecting trade goods
The "Bring goods to trade depot" screen can now see inside bins, and you can select individual items within bins for trade instead of the entire bin, if you so choose. You can also search for contents within bins, even when in "bring the bin" mode. For example, you can find the "Gem bin"s that contain rubies by searching for "ruby".
Search and sort for squad assignment screen
The squad assignment screen was overhauled since the last beta in response to lots of great feedback. Thank you to all who responded with opinions and suggestions and helped us make this screen better!
The default sort is now "melee effectiveness", which takes both weapon skill and physical attributes into account.
Thanks to research into combat mechanics by community contributor Halifay, you can also sort by melee and ranged "potential", which predicts how effective a unit could become in the future, given adequate training.
There are also configurable filters to show or hide units in other squads, appointed/elected officials (like your manager, high priests, and doctors), and nobility.
Of course, if you know exactly who you're looking for, you can also search for units by name. Searching for skills was removed because it was too confusing. Sorting by skills is still available, though.
Generated release notes
New tools, fixes, and improvements
(These notes are cumulative with the previous beta and represent all changes since the last stable release)
New Tools
devel/scan-vtables
: Scan and dump likely vtable addresses (for memory research)hide-interface
: hide the vanilla UI elements for clean screenshots or laid-back fortress observinghide-tutorials
: hide the DF tutorial popups; enable in the System tab ofgui/control-panel
New Features
exportlegends
: new overlay that integrates with the vanilla "Export XML" button. Now you can generate both the vanilla export and the extended data export with a single click!sort
: search and sort for squad assignment screenzone
: advanced unit assignment screens for cages, restraints, and pits/ponds
Fixes
- Core:
- reload scripts in mods when a world is unloaded and immediately loaded again
- fix text getting added to DFHack text entry widgets when Alt- or Ctrl- keys are hit
caravan
:- corrected prices for cages that have units inside of them
- Correct price adjustment values in trade agreement details screen
- Apply both import and export trade agreement price adjustments to items being both bought or sold to align with how vanilla DF calculates prices
- cancel any active TradeAtDepot jobs if all caravans are instructed to leave
emigration
:- fix errors loading forts after dwarves assigned to work details or workshops have emigrated
- fix citizens sometimes "emigrating" to the fortress site
fix/retrieve-units
: fix retrieved units sometimes becoming duplicated on the mapgui/launcher
,gui/gm-editor
: recover gracefully when the saved frame position is now offscreenorders
: prevent import/export overlay from appearing on the create workorder screenquickfort
: cancel old dig jobs that point to a tile when a new designation is applied to the tilestarvingdead
: ensure sieges end properly when undead siegers starvesuspendmanager
:- Fix the overlay enabling/disabling
suspendmanager
unexpec...
- Fix the overlay enabling/disabling
DFHack 50.09-r3rc1
Q: How do I download DFHack?
A: Either add to your Steam library from our Steam page or scroll to the latest release on our GitHub releases page, expand the "Assets" list, and download the file for your platform (e.g. dfhack-XX.XX-rX-Windows-64bit.zip
.
This release is compatible with all distributions of Dwarf Fortress: Steam, Itch, and Classic.
Please report any issues (or feature requests) on the DFHack GitHub issue tracker. When reporting issues, please upload a zip file of your savegame and a zip file of your mods
directory to the cloud and add links to the GitHub issue. Make sure your files are downloadable by "everyone with the link". We need your savegame to reproduce the problem and test the fix, and we need your active mods so we can load your savegame. Issues with savegames and mods attached get fixed first!
Announcements
Linux support!, PSAs
Linux support!
Both DF and DFHack now run natively on Linux. If you're on Linux, we encourage you to try it! The interface is noticeably snappier, FPS is up, and load times are reduced. If you're subscribed to DF and DFHack on Steam, here's how to switch over:
- In the Steam client, open the properties for Dwarf Fortress
- In the "Betas" section, switch to the "beta" branch
- Let that finish updating
- Select the "Compatibility" section and deselect "Force the use of a specific Steam Play compatibility tool"
- DF should update again with the Linux native version
You can tell if you did it right (and sometimes Steam gets stuck somewhere along the way and you have to fiddle with it) if you no longer have Dwarf Fortress.exe
in your DF directory and instead have dwarfort
, which is the Linux binary. The plan is to "officially" release Linux support with DF 50.10, so once DF 50.10 comes out, you should be able to switch back to the default Steam branch and keep the native Linux support.
Then, do the same thing for DFHack. switching to the "beta" branch (if you're not there already) and turning off the compatibility layer.
Major caveat for this beta release
This particular beta release of Dwarf Fortress has address layout randomization enabled. This causes some trouble for DFHack since DFHack needs to know the memory addresses of several key data structures. For this release only, be sure to start DF by launching DFHack from the Steam client or by running the ./dfhack
commandline startup script. That will normalize the address space and allow DF to run with DFHack. Otherwise, DF will crash on startup. Again, this is only for this release. Future releases will not need this workaround and should go back to allowing you to start DF from either the Dwarf Fortress or DFHack Steam client entries, or from either the ./dwarfort
or ./dfhack
commandline commands.
The DFHack terminal console works differently on Linux
You can run DF with DFHack by starting DFHack in the Steam client. However, if you want an external DFHack terminal console, you have to run from the commandline.
On Windows, you could use the show
command to pop up an external DFHack terminal console. You could use this for running DFHack commands from outside the game window, and the external terminal is the only way to run commandline-interactive DFHack commands like tiletypes
and the interactive mode of the lua
interpreter.
Linux has a different method of providing a terminal console. You can't spawn it dynamically like you can on Windows. You have to start DF from the commandline, and the terminal from which you ran ./dwarfort
becomes the terminal console. This should be a familiar process to many Linux users (most Linux commands work this way), but the change is jarring if you're not expecting it. We're also looking into providing a virtual console that doesn't depend on an existing system console so you can still get a console even if you run from Steam, but that work is far from being completed.
You can still launch DFHack from Steam if you want to. Many tools log information and errors to the console, though, so if you run into strange issues, it might be useful to try running from the commandline to see if there is diagnostic output there that can help you.
PSAs
As always, remember that, just like the vanilla DF game, DFHack tools can also have bugs. It is a good idea to save often and keep backups of the forts that you care about.
Many DFHack tools that worked in previous (pre-Steam) versions of DF have not been updated yet and are marked with the "unavailable" tag in their docs. If you try to run them, they will show a warning and exit immediately. You can run the command again to override the warning (though of course the tools may not work). We make no guarantees of reliability for the tools that are marked as "unavailable".
The in-game interface for running DFHack commands (gui/launcher
) will not show "unavailable" tools by default. You can still run them if you know their names, or you can turn on dev mode by hitting Ctrl-D while in gui/launcher
and they will be added to the autocomplete list. Some tools do not compile yet and are not available at all, even when in dev mode.
If you see a tool complaining about the lack of a cursor, know that it's referring to the keyboard cursor (which used to be the only real option in Dwarf Fortress). You can enable the keyboard cursor by entering mining mode or selecting the dump/forbid tool and hitting Alt-K (the DFHack keybinding for toggle-kbd-cursor
. We're working on making DFHack tools more mouse-aware and accessible so this step isn't necessary in the future.
Highlights
Squad assignment search and sort, animal assignment screens, exportlegends UI integration, hide UI elements
Search and sort for squad assignment screen
When you bring up the screen to assign units to squads, there are now widgets for searching and sorting. The default sort is by "best melee skill", but you can choose from a variety of relevant ascending or descending sorting orders.
You can also search. Searching matches either the unit name or a skill that the unit has. Sorting by "leadership" shows units that have any leadership-related abilities, like teaching and military tactics training, but if you just want to see dwarves with military tactics training, search for "tactics".
There have already been many good suggestions for additional sorting options, which we'll try to get into a future beta/release.
Animal assignment
The "Assign to pasture" screen released in the previous DFHack version has been expanded and generalized to support cages, restraints, and pits/ponds. Please tell us if you have any additional needs for animal assignment that those screens don't meet!
One-click UI integration for exportlegends
exportlegends
now sports a new integration with the vanilla "Export XML" button. Now you can generate both the vanilla export and the extended data export with a single click!
Onscreen HUD getting in your way? Hide it!
hide-interface
hides all the vanilla UI elements for clean screenshots or distraction-free fortress watching. Even with the interface hidden, you can still pause/unpause the game with spacebar and move around the map with the keyboard or mouse. Hide that cluster of urgent notifications bubbles for a while and just enjoy watching your citizens scurry around : )
Generated release notes
New tools, fixes, and improvements
New Tools
devel/scan-vtables
: Scan and dump likely vtable addresses (for memory research)hide-interface
: hide the vanilla UI elements for clean screenshots or laid-back fortress observing
New Features
exportlegends
: new overlay that integrates with the vanilla "Export XML" button. Now you can generate both the vanilla export and the extended data export with a single click!sort
: search and sort for squad assignment screenzone
: advanced unit assignment screens for cages, restraints, and pits/ponds
Fixes
- Core:
- reload scripts in mods when a world is unloaded and immediately loaded again
- fix text getting added to DFHack text entry widgets when Alt- or Ctrl- keys are hit
caravan
:- Correct price adjustment values in trade agreement details screen
- Apply both import and export trade agreement price adjustments to items being both bought or sold to align with how vanilla DF calculates prices
orders
: prevent import/export overlay from appearing on the create workorder screenstarvingdead
: ensure sieges end properly when undead siegers starvesuspendmanager
:- Fix the overlay enabling/disabling
suspendmanager
unexpectedly - Improve the detection on "T" and "+" shaped high walls
- Fix the overlay enabling/disabling
Misc Improvements
- Surround DFHack-specific UI elements with square brackets instead of red-yellow blocks for better readability
devel/lsmem
: added support for filtering by memory addresses and filenameshotkeys
: don't display DFHack logo in legends mod...
DFHack 50.09-r2
Q: How do I download DFHack?
A: Either add to your Steam library from our Steam page or scroll to the latest release on our GitHub releases page, expand the "Assets" list, and download the file for your platform (e.g. dfhack-XX.XX-rX-Windows-64bit.zip
.
This release is compatible with all distributions of Dwarf Fortress: Steam, Itch, and Classic.
Please report any issues (or feature requests) on the DFHack GitHub issue tracker. When reporting issues, please upload a zip file of your savegame and a zip file of your mods
directory to the cloud and add links to the GitHub issue. Make sure your files are downloadable by "everyone with the link". We need your savegame to reproduce the problem and test the fix, and we need your active mods so we can load your savegame. Issues with savegames and mods attached get fixed first!
Announcements
Distribute quickfort blueprints in mods, PSAs
You can now distribute your quickfort blueprints in mods!
Think you have a cool fortress design that you want to share with the community? The effort required to share your designs has now been cut down significantly. DFHack quickfort
now supports blueprints that have been distributed with mods!
The blueprint in the screenshot comes from a mod with only two files:
mods/myk002 blueprints/info.txt
mods/myk002 blueprints/blueprints/from_mod.csv
with info.txt
containing just the basic mod metadata (detailed in the DF mod guide). You can distribute these mods anyway you like, including from the DF Steam Workshop.
How do you make blueprints of your fort to distribute? DFHack's gui/blueprint
will take a snapshot of your fort and create a series of blueprints for you. You can also make edits with a text editor or online spreadsheet app to do some really advanced stuff.
PSAs
As always, remember that, just like the vanilla DF game, DFHack tools can also have bugs. It is a good idea to save often and keep backups of the forts that you care about.
Many DFHack tools that worked in previous (pre-Steam) versions of DF have not been updated yet and are marked with the "unavailable" tag in their docs. If you try to run them, they will show a warning and exit immediately. You can run the command again to override the warning (though of course the tools may not work). We make no guarantees of reliability for the tools that are marked as "unavailable".
The in-game interface for running DFHack commands (gui/launcher
) will not show "unavailable" tools by default. You can still run them if you know their names, or you can turn on dev mode by hitting Ctrl-D while in gui/launcher
and they will be added to the autocomplete list. Some tools do not compile yet and are not available at all, even when in dev mode.
If you see a tool complaining about the lack of a cursor, know that it's referring to the keyboard cursor (which used to be the only real option in Dwarf Fortress). You can enable the keyboard cursor by entering mining mode or selecting the dump/forbid tool and hitting Alt-K (the DFHack keybinding for toggle-kbd-cursor
. We're working on making DFHack tools more mouse-aware and accessible so this step isn't necessary in the future.
Highlights
search and sort, copy/paste support, ASCII warm/damp highlights, other new tools
Initial screens for search and sort
The first few screens are done for search/filter/sort support! For starters, we decided to tackle the animal assignment to pasture screen and the trade screens, both of which are a frequent source of frustration for players. There is generally not enough room to add vanilla-sized buttons, so DFHack screen links will appear surrounded with red and yellow bars to to distinguish them from vanilla widgets.
The screen that comes up can be filtered and sorted by whether and where the animals are pastured/caged, by their friendliness or tame status, and by various other properties. All animals of a particular species are now listed next to each other so you can find them easily.
The trade screens got a similar treatment. There are two new screens, one for bringing trade goods to the depot, and one for doing the actual trading. In both, items that are ethically unacceptable to the traders that you are trading with and items that are forbidden to export by your nobles are automatically filtered out, though you can change the filters if you like. Both screens also make bins safe and easy to work with.
The bring goods to depot screen allows you to find the items that you want to sell and mark them for trading. For example, you can move the "condition" slider to only show damaged items and then mark them all for trade with a single click.
The trade screen provides similar filter and selection support for items being bought and sold. By default, only the contents of bins are listed and traded and the bins themselves aren't traded. You can toggle this behavior and trade bins if you like, though.
Copy/paste support
With the move to SDL2 comes new clipboard integration capabilities. DFHack's text entry fields, such as the command editing field in gui/launcher
, now support copy, paste, and cut. Ctrl-V will paste from the system clipboard into the DFHack text field. This is especially useful when pasting in DFHack commands that you find on the internet! Ctrl-C will copy text out that you can paste into another application, and Ctrl-X will copy the text and also clear the field (so it's a convenient way of just clearing the text quickly even if you don't need to copy it).
Note that there is no way to just select a portion of the text, though, so all copy and cut operations apply to all text in the field.
Warm and damp indicators in ASCII mode
DF does not distinguish damp or warm tiles when in ASCII mode. This can be very frustrating for ASCII-mode players that have to play without this information.
DFHack now automatically highlights damp tiles in blue and warm tiles in red when in ASCII mode and a mining operation is selected. In other words, the visual feedback in ASCII now matches what premium players get in graphics mode.
Other new tools
Some long-standing requests were finally fulfilled in this release, with the return of a few fan-favorite tools and one new game fix.
3dveins
replaces vanilla DF's blobby vein generation with veins that flow smoothly and naturally between z-levels. Want a more natural looking geology? Try running this command right after a new embark!dwarfvet
allows your animals to have their wounds treated at hospitals, prolonging their life and usefulness.fix/empty-wheelbarrows
dislodges rocks that get stuck in your wheelbarrows when a hauling dwarf gets distracted and the full wheelbarrow gets abandoned somewhere. This makes those wheelbarrows useful for hauling again. Enable this tool in the "Maintenance" tab ofgui/control-panel
to automatically keep your wheelbarrows usable!
Generated release notes
New tools, fixes, and improvements
New Tools
3dveins
: reinstated for v50, this plugin replaces vanilla DF's blobby vein generation with veins that flow smoothly and naturally between z-levelscaravan
: new trade screen UI replacements for bringing goods to trade depot and tradingdig
: newdig.asciiwarmdamp
overlay that highlights warm and damp tiles when in ASCII mode. there is no effect in graphics mode since the tiles are already highlighted theredwarfvet
: reinstated and updated for v50's new hospital mechanics; allow your animals to have their wounds treated at hospitalsfix/empty-wheelbarrows
: new script to empty stuck rocks from all wheelbarrows on the mapzone
: new searchable, sortable, filterable screen for assigni...
DFHack 50.09-r1
Q: How do I download DFHack?
A: Either add to your Steam library from our Steam page or scroll to the latest release on our GitHub releases page, expand the "Assets" list, and download the file for your platform (e.g. dfhack-XX.XX-rX-Windows-64bit.zip
.
This release is compatible with all distributions of Dwarf Fortress: Steam, Itch, and Classic.
Please report any issues (or feature requests) on the DFHack GitHub issue tracker. When reporting issues, please upload a zip file of your savegame and a zip file of your mods
directory to the cloud and add links to the GitHub issue. Make sure your files are downloadable by "everyone with the link". We need your savegame to reproduce the problem and test the fix, and we need your active mods so we can load your savegame. Issues with savegames and mods attached get fixed first!
Announcements
If symbol keys don't work, reset your keybindings, PSAs
If symbol keys don't work, reset your keybindings
DF 50.09 includes a major infrastructure upgrade from SDL1 to SDL2. Part of this is a complete change to how input processing works. If you find you can't input shift-symbol characters (like :
or ?
on most keyboards) into DFHack windows, go into your DF settings and reset your keybindings to the defaults. That should get you working again.
PSAs
As always, remember that, just like the vanilla DF game, DFHack tools can also have bugs. It is a good idea to save often and keep backups of the forts that you care about.
Many DFHack tools that worked in previous (pre-Steam) versions of DF have not been updated yet and are marked with the "unavailable" tag in their docs. If you try to run them, they will show a warning and exit immediately. You can run the command again to override the warning (though of course the tools may not work). We make no guarantees of reliability for the tools that are marked as "unavailable".
The in-game interface for running DFHack commands (gui/launcher
) will not show "unavailable" tools by default. You can still run them if you know their names, or you can turn on dev mode by hitting Ctrl-D while in gui/launcher
and they will be added to the autocomplete list. Some tools do not compile yet and are not available at all, even when in dev mode.
If you see a tool complaining about the lack of a cursor, know that it's referring to the keyboard cursor (which used to be the only real option in Dwarf Fortress). You can enable the keyboard cursor by entering mining mode or selecting the dump/forbid tool and hitting Alt-K (the DFHack keybinding for toggle-kbd-cursor
. We're working on making DFHack tools more mouse-aware and accessible so this step isn't necessary in the future.
Generated release notes
Most changes in this release have to do with migrating to SDL2 and are not visible to the player.
New tools, fixes, and improvements
Misc Improvements
caravan
: new overlay for selecting all/none on trade request screensuspendmanager
: don't suspend constructions that are built over open spaceunsuspend
: new icons for planned and suspended buildings
Structures
tiletype_shape
: changed RAMP_TOP and ENDLESS_PIT to not walkable to reflect how scripts actually need these types to be treated
DFHack 50.08-r4
Q: How do I download DFHack?
A: Either add to your Steam library from our Steam page or scroll to the latest release on our GitHub releases page, expand the "Assets" list, and download the file for your platform (e.g. dfhack-XX.XX-rX-Windows-64bit.zip
.
This release is compatible with all distributions of Dwarf Fortress: Steam, Itch, and Classic.
Please report any issues (or feature requests) on the DFHack GitHub issue tracker. When reporting issues, please upload a zip file of your savegame and a zip file of your mods
directory to the cloud and add links to the GitHub issue. Make sure your files are downloadable by "everyone with the link". We need your savegame to reproduce the problem and test the fix, and we need your active mods so we can load your savegame. Issues with savegames and mods attached get fixed first!
Announcements
PSAs
PSAs
As always, remember that, just like the vanilla DF game, DFHack tools can also have bugs. It is a good idea to save often and keep backups of the forts that you care about.
Many DFHack tools that worked in previous (pre-Steam) versions of DF have not been updated yet and are marked with the "unavailable" tag in their docs. If you try to run them, they will show a warning and exit immediately. You can run the command again to override the warning (though of course the tools may not work). We make no guarantees of reliability for the tools that are marked as "unavailable".
The in-game interface for running DFHack commands (gui/launcher
) will not show "unavailable" tools by default. You can still run them if you know their names, or you can turn on dev mode by hitting Ctrl-D while in gui/launcher
and they will be added to the autocomplete list. Some tools do not compile yet and are not available at all, even when in dev mode.
If you see a tool complaining about the lack of a cursor, know that it's referring to the keyboard cursor (which used to be the only real option in Dwarf Fortress). You can enable the keyboard cursor by entering mining mode or selecting the dump/forbid tool and hitting Alt-K (the DFHack keybinding for toggle-kbd-cursor
. We're working on making DFHack tools more mouse-aware and accessible so this step isn't necessary in the future.
Highlights
logistics, Dreamfort, and suspendmanager
logistics
When you select a stockpile, you'll now see a panel that will let you toggle its automation features. Items and animals brought to that stockpile can be automatically marked for melting, trading, dumping, and/or training.
For example, you can set up cage traps for catching wild game. When you catch something, your dwarves will bring the caged animal to your Animals stockpile. If you enable automatic training on that stockpile, the animals will automatically get a trainer assigned to them. Combine this with autobutcher
, which can mark the trained animals for butchering, and you now have a low-toil food supply chain for your kitchens!
Similarly, if you enable automatic trading for your trade goods stockpile, all items in the stockpile will be marked for trading and be automatically brought to the trade depot when a merchant caravan arrives.
Dreamfort
Dreamfort is the result of over a decade of experimentation and revision from some of Dwarf Fortress's most experienced players. It is a fully functional, pre-designed fortress you can build yourself from gui/quickfort
blueprints. If you're having trouble with getting your forts to work smoothly, try building Dreamfort. The blueprints walk you through the process of creating the fortress so you can learn from its design, progression, and configuration. You can even reuse individual blueprints for the parts you especially like to extend your own designs.
The Dreamfort walkthroughs and blueprints bring you from embark all the way through to a 200-strong mountainhome. Screenshots for all the levels and links to more information here: https://docs.dfhack.org/en/stable/docs/guides/quickfort-library-guide.html#dreamfort.
If you want to explore it interactively, you can download a pre-built Dreamfort from DFFD: https://dffd.bay12games.com/file.php?id=15434.
suspendmanager
Logic for when to suspend building jobs has been upgraded. Now suspendmanager
is much smarter when you're building in areas with limited access paths. For example, if you fill a corridor or build a high wall, it will now correctly realize that a wall tile can block access to a another tile farther away.
Moreover, suspendmanager
now also considers smoothing and engraving jobs. For example, if you attempt to build a statue on top of flooring that is designated for smoothing, it will now allow the smoothing job to be completed first before the statue blocks it.
Generated release notes
New tools, fixes, and improvements
New Plugins
logistics
: automatically mark and route items or animals that come to monitored stockpiles. options are toggleable on an overlay that comes up when you have a stockpile selected.
Fixes
buildingplan
: don't include artifacts when max quality is masterfuldig-now
: clear item occupancy flags for channeled tiles that had items on thememigration
: reassign home site for emigrating units so they don't just come right back to the fortgui/create-item
: allow blocks to be made out of wood when using the restrictive filtersgui/liquids
: ensure tile temperature is set correctly when painting water or magmagui/quickfort
:- allow traffic designations to be applied over buildings
- protect against meta blueprints recursing infinitely if they include themselves
gui/sandbox
: allow creatures that have separate caste-based graphics to be spawned (like ewes/rams)RemoteFortressReader
: fix a crash with engravings with undefined imagesworkorder
: preventautoMilkCreature
from over-counting milkable animals, which was leading to cancellation spam for theMilkCreature
job
Misc Improvements
- Blueprint library:
- dreamfort: full rewrite and update for DF v50
- pump_stack: updated walkthrough and separated dig and channel steps so boulders can be cleared
- aquifer_tap: updated walkthrough
autonick
: additional nicknames based on burrowing animals, colours, gems, and mineralscombine
: reduce max different stacks in containers to 30 to prevent contaners from getting overfulldig-now
: can now handle digging obsidian that has been formed from magma and watergui/autodump
: add option to clear thetrader
flag from teleported items, allowing you to reclaim items dropped by merchantsgui/control-panel
:- add some popular startup configuration commands for
autobutcher
andautofarm
- add option for running
fix/blood-del
on new forts (enabled by default)
- add some popular startup configuration commands for
gui/quickfort
:- adapt "cursor lock" to mouse controls so it's easier to see the full preview for multi-level blueprints before you apply them
- only display post-blueprint messages once when repeating the blueprint up or down z-levels
gui/sandbox
: when creating citizens, give them names appropriate for their racesorders
:- only display import/export/sort/clear panel on main orders screen
- refine order conditions for library orders to reduce cancellation spam
prioritize
: add wild animal management tasks and lever pulling to the default list of prioritized job typesquickfort
: significant rewrite for DF v50! now handles zones, locations, stockpile configuration, hauling routes, and morestockpiles
: addedbarrels
,organic
,artifacts
, andmasterworks
stockpile presetssuspendmanager
:- now suspends construction jobs on top of floor designations, protecting the designations from being erased
- suspend blocking jobs when building high walls or filling corridors
workorder
: reduce existing orders for automatic shearing and milking jobs when animals are no longer available
Removed
gui/automelt
: replaced by an overlay panel that appears when you click on a stockpile
Structures
abstract_building_libraryst
: initialize unknown variables as DF doesmisc_trait_type
: realign
Documentation
blueprint-library-guide
: update Dreamfort screenshots and links, addaquifer_tap
screenshot
DFHack 50.08-r3
Generated release notes
Fixes
- Fix crash for some players when they launch DF outside of the Steam client
DFHack 50.08-r2
Q: How do I download DFHack?
A: Either add to your Steam library from our Steam page or scroll down to the bottom of the GitHub release post, expand the "Assets" list, and download the file for your platform (e.g. dfhack-XX.XX-rX-Windows-64bit.zip
.
This release is compatible with all distributions of Dwarf Fortress: Steam, Itch, and Classic.
Please report any issues (or feature requests) on the DFHack GitHub issue tracker. When reporting issues, please upload a zip file of your savegame and a zip file of your mods
directory to the cloud and add links to the GitHub issue. Make sure your files are downloadable by "everyone with the link". We need your savegame to reproduce the problem and test the fix, and we need your active mods so we can load your savegame. Issues with savegames and mods attached get fixed first!
Announcements
Armok mode vs. Mortal mode, Ongoing large projects, PSAs
Armok mode vs. Mortal mode
If DFHack makes the game less fun for you because the tools are too powerful, please consider enabling "Mortal mode". Open the "Preferences" tab of gui/control-panel
and toggle the "Show armok tools" setting. This will hide any tools that are tagged as "armok" (that is, god-mode tools) from gui/launcher
, gui/control-panel
, the DFHack logo popup menu, and anywhere else DFHack commands are listed. Global hotkeys for those tools will also cease to function. All productivity, analysis, bugfix, and design tools will still be shown as normal.
Ongoing large projects
Here are the projects we're working on right now (and the [@ person] on DFHack Discord you should talk to if you have opinions). If you are interested in early access, please join the "Beta - DFHack pre-releases" branch in your Steam client. You can also download pre-releases from GitHub.
buildingplan
v2 [@TaxiService] - clearer UI, easier configuration, filter historystocks
[@silver_fly] - item management interface, including bulk actions like "mark all worn clothing for trade"stockpiles
,logistics
,quickfort
[@myk002] - stockpile configuration presets, automatic dumping, trading, or melting of stockpile contents, stockpile and zone support forquickfort
gui/design
v2 [@coskerstrike] - UI overhaul, performance improvements
and, of course, a host of smaller bugfixes and features.
PSAs
As always, remember that, just like the vanilla DF game, DFHack tools can also have bugs. It is a good idea to save often and keep backups of the forts that you care about.
Many DFHack tools that worked in previous (pre-Steam) versions of DF have not been updated yet and are marked with the "unavailable" tag in their docs. If you try to run them, they will show a warning and exit immediately. You can run the command again to override the warning (though of course the tools may not work). We make no guarantees of reliability for the tools that are marked as "unavailable".
The in-game interface for running DFHack commands (gui/launcher
) will not show "unavailable" tools by default. You can still run them if you know their names, or you can turn on dev mode by hitting Ctrl-D while in gui/launcher
and they will be added to the autocomplete list. Some tools do not compile yet and are not available at all, even when in dev mode.
If you see a tool complaining about the lack of a cursor, know that it's referring to the keyboard cursor (which used to be the only real option in Dwarf Fortress). You can enable the keyboard cursor in the DF settings, and you can show it by entering mining mode or selecting the dump/forbid tool. We're working on making DFHack tools more mouse-aware and accessible.
Highlights
exportlegends, gui/mod-manager, gui/sandbox, necronomicon
exportlegends
There are a variety of tools for digging into the stories in legends mode. Most of them use the extra legends information DFHack exports with the exportlegends
tool to give you a more complete picture of what is going on.
How to use:
- Enter legends mode as usual from DF
- Click the green button to do the vanilla export
- Open
gui/launcher
and runexportlegends
exportlegends
might take a while to run if your world is large. Now you should have two .xml
files in your Dwarf Fortress folder. The ...-legends_plus.xml
file is the extended export from DFHack.
Note that DF itself used to export more information than it does now, and many tools can't cope with the lack of vanilla information. The current best tool to use for external legends browsing is the cross-platform Legends Browser 2
Happy legends browsing!
gui/mod-manager
For those of us who use mods, creating a new world can be very frustrating. Each mod must be manually re-enabled for every new created world, and for long mod lists, that is quite a chore.
Enter gui/mod-manager
. You don't actually have to run the command. It will show up as an overlay automatically when you create a new world. If you have a default mod list saved already, you don't even need to go into the DF "Mods" page. As soon as you start the world creation process, gui/mod-manager
will automatically apply your mod list.
To set it up, start creating a world and set up your mods as normal. Then click on the "Mod manager" button at the bottom of the page or hit the m
hotkey. This will bring up a dialog where you can save your current mod list and set it as the default for future worlds. That's it.
gui/sandbox
This tool stretches the bounds of "Armok mode". It gives you an interface for willing units, trees, and items into existence. Feeling like you need a challenge? Set units to "hostile" and spawn yourself up an invading army : )
necronomicon
Sometimes you want your dwarves to become necromancers, and sometimes you don't. However, you can't control what visitors or returning raiders bring back into your fort. It used to be that you'd have to manually scan through every book and see whether it contains the "secrets of life and death". Now, a quick run of the necronomicon
command will give you a summary of whether you have any books with secrets in your fort and what their titles (and powers) are. Then you can sequester those books or promote them on display in your library, as per your agenda.
Generated release notes
New tools, fixes, and improvements
New Plugins
add-spatter
: (reinstated) allow mods to add poisons and magical effects to weaponschangeitem
: (reinstated) change item material, quality, and subtypecreateitem
: (reinstated) create arbitrary items from the command linederamp
: (reinstated) removes all ramps designated for removal from the mapflows
: (reinstated) counts map blocks with flowing liquidslair
: (reinstated) mark the map as a monster lair (this avoids item scatter when the fortress is abandoned)luasocket
: (reinstated) provides a Lua API for accessing network socketswork-now
: (reinstated, renamed fromworkNow
) prevent dwarves from wandering aimlessly with "No job" after completing a task
New Scripts
assign-minecarts
: (reinstated) quickly assign minecarts to hauling routesdiplomacy
: view or alter diplomatic relationshipsexportlegends
: (reinstated) export extended legends information for external browsingfix/stuck-instruments
: fix instruments that are attached to invalid jobs, making them unusable. turn on automatic fixing ingui/control-panel
in theMaintenance
tab.gui/autodump
: point and click item teleportation and destruction interface (available only ifarmok
tools are shown)gui/mod-manager
: automatically restore your list of active mods when generating new worldsgui/sandbox
: creation interface for units, trees, and items (available only ifarmok
tools are shown)light-aquifers-only
: (reinstated) convert heavy aquifers to lightmodtools/create-item
: (reinstated) commandline and API interface for creating itemsnecronomicon
: search fort for items containing the secrets of life and death
Fixes
- DFHack screen backgrounds now use appropriate tiles in DF Classic
- RemoteServer: fix crash on malformed json in
dfhack-config/remote-server.json
autolabor
: work detail override warning now only appears on the work details screendeathcause
: fix incorrect weap...
DFHack 50.08-r1
Q: How do I download DFHack?
A: Either add to your Steam library from our Steam page or scroll down to the bottom of the GitHub release post, expand the "Assets" list, and download the file for your platform (e.g. dfhack-XX.XX-rX-Windows-64bit.zip
.
This release is compatible with all distributions of Dwarf Fortress: Steam, Itch, and Classic.
Please report any issues (or feature requests) on the DFHack GitHub issue tracker. When reporting issues, please upload a zip file of your savegame and a zip file of your mods
directory to the cloud and add links to the GitHub issue. Make sure your files are downloadable by "everyone with the link". We need your savegame to reproduce the problem and test the fix, and we need your active mods so we can load your savegame. Issues with savegames and mods attached get fixed first!
Announcements
What's next?, Poll results, Terminal now hidden by default, PSAs
What's next?
Here are the projects we're working on right now (and the [@ person] on DFHack Discord you should talk to if you have opinions). If you are interested in early access, please join the "Beta - DFHack pre-releases" branch in your Steam client. You can also download pre-releases from GitHub.
buildingplan
v2 [@TaxiService] - clearer UI, easier configuration, filter historystocks
[@silver_fly] - item management interface, including bulk actions like "mark all worn clothing for trade"stockpiles
andlogistics
[@myk002] - stockpile configuration presets, automatic dumping, trading, or melting of stockpile contentsgui/design
v2 [@coskerstrike] - UI overhaul, performance improvementsgui/create-unit
[@Thazzeus] - unit spawning interface
and, of course, a host of smaller bugfixes and features.
Poll results
We ran a poll on reddit to hear your opinions for what DFHack's Next Big Thing should be. The results:
- 30% manipulator - in-game Dwarf Therapist-like labor assignment and unit management interface
- 18% search, embark-assistant (tie) - better search functionality for vanilla dialogs, extended options for embark location discovery, respectively
- 15% tooltips - in-game help tooltips for DFHack UIs
- 11% quickfort - stockpile and zone support for blueprints, including Dreamfort support
- 6% exportlegends - extended data for legends export, allowing external tools like Legends Viewer to work
These are all huge projects, and don't expect their completion any time soon, but the results of the poll helped us set priorities for upcoming development. If you have opinions about any of those tools, or if you're just curious about the implementation plans, or if you'd like to help, please check out the GitHub issues where they are being discussed (hyperlinked above).
Terminal hidden by default
From a less formal poll, it seems that most players consider the DFHack terminal (the external DFHack window that pops up when you start DF) to be a nuisance, or at least not necessary. The terminal window will now be hidden and out of the way by default. You can unhide the terminal at any time by running the show
command in gui/launcher
(and hide it again with the hide
command).
If you want to keep the terminal window shown at startup, go to the "Preferences" tab of gui/control-panel
and toggle the option there.
Note that text-interactive commands, like the built-in lua
interpreter or the tiletypes
command, can only be run from that external terminal window. Most players will never have need to run these, though.
PSAs
As always, remember that, just like the vanilla DF game, DFHack tools can also have bugs. It is a good idea to save often and keep backups of the forts that you care about.
Many DFHack tools that worked in previous (pre-Steam) versions of DF have not been updated yet and are marked with the "unavailable" tag in their docs. If you try to run them, they will show a warning and exit immediately. You can run the command again to override the warning (though of course the tools may not work). We make no guarantees of reliability for the tools that are marked as "unavailable".
The in-game interface for running DFHack commands (gui/launcher
) will not show "unavailable" tools by default. You can still run them if you know their names, or you can turn on dev mode by hitting Ctrl-D while in gui/launcher
and they will be added to the autocomplete list. Some tools do not compile yet and are not available at all, even when in dev mode.
If you see a tool complaining about the lack of a cursor, know that it's referring to the keyboard cursor (which used to be the only real option in Dwarf Fortress). You can enable the keyboard cursor in the DF settings, and you can show it by entering mining mode or selecting the dump/forbid tool. We're working on making DFHack tools more mouse-aware and accessible.
Highlights
Mortal mode; Dude, where's my planner?
Mortal mode
We finally have an answer for those players who want to use DFHack for its bug fixes, interface improvements, and productivity tools, but feel uncomfortable with the tools that grant god-like powers over the game. Armok, if you didn't already know, is the god of Dwarf Fortress. If you don't want to see these "armok" tools, go into gui/control-panel
, on the "Preferences" tab, and toggle on the Hide "armok" tools in command lists
setting.
Dude, where's my planner?
You may notice that the DFHack building planner appears to be missing. Don't worry, it's not gone. It's just minimized by default. If you want to use it again, just expand it by clicking on the "show planner" button and it will stay expanded, just like it was before.
Why did we do this? Now that DFHack has entered the "stable release" phase, we want to go back to our roots and not supplant vanilla functionality by default. From now on, if there is a DFHack interface enhancement that can replace a vanilla element, it will show up as a minimized panel that you can expand and use. The panels that simply add extra functionality without getting in the way, like order import/export and the trade screen enhancements, will still stay expanded by default.
Generated release notes
New tools, fixes, and improvements
Fixes
autoclothing
: eliminate game lag when there are many inventory items in the fortbuildingplan
:- fixed size limit calculations for rollers
- fixed items not being checked for accessibility in the filter and item selection dialogs
deteriorate
: ensure remains of enemy dwarves are properly deteriorateddig-now
: properly detect and complete smoothing designations that have been converted into active jobssuspendmanager
: Fix over-aggressive suspension of jobs that could still possibly be done (e.g. jobs that are partially submerged in water)
Misc Improvements
buildingplan
:- planner panel is minimized by default and now remembers minimized state
- can now filter by gems (for gem windows) and yarn (for ropes in wells)
combine
: Now supports ammo, parts, powders, and seeds, and combines into containersdeteriorate
: add option to exclude useable parts from deteriorationgui/control-panel
:- add preference option for hiding the terminal console on startup
- add preference option for hiding "armok" tools in command lists
gui/gm-editor
:- press
g
to move the map to the currently selected item/unit/building - press
Ctrl-D
to toggle read-only mode to protect from accidental changes; this state persists across sessions - new
--freeze
option for ensuring the game doesn't change while you're inspecting it
- press
gui/launcher
: DFHack version now shown in the default help textgui/prerelease-warning
: widgets are now clickableoverlay
: add the DFHack version string to the DF title screenDwarf Therapist
: add a warning to the Labors screen when Dwarf Therapist is active so players know that changes they make to that screen will have no effect. If you're starting a new embark and nobody seems to be doing anything, check your Labors tab for this warni...
DFHack 50.07-r1
Q: How do I download DFHack?
A: Either add to your Steam library from our Steam page or scroll down to the bottom of this post, expand the "Assets" list, and download the dfhack-50.07-r1-Windows-64bit.zip
file.
This release is compatible with all distributions of Dwarf Fortress: Steam, Itch, and Classic.
Please report any issues (or feature requests) on the DFHack GitHub issue tracker. When reporting issues, please upload a zip file of your savegame and a zip file of your mods
directory to the cloud and add links to the GitHub issue. Make sure your files are downloadable by "everyone with the link". We need your savegame to reproduce the problem and test the fix, and we need your active mods so we can load your savegame. Issues with savegames and mods attached get fixed first!
What the heck is DFHack?
Project goals, team members, community contributions
This is DFHack's first stable release for Dwarf Fortress in the v50 era, so many of you will be reading the release notes for the first time. A little background is in order.
DFHack is an add-on for Dwarf Fortress that enables mods and tools to significantly extend the game. The default DFHack distribution contains a wide variety of these tools, including bugfixes, interface improvements, automation agents, design blueprints, modding building blocks, and more. Third-party tools (e.g. mods downloaded from Steam Workshop or the forums) can also seamlessly integrate with the DFHack framework and extend the game far beyond what can be done by just modding the raws.
DFHack’s mission is to provide tools and interfaces for players and modders to:
- expand the bounds of what is possible in Dwarf Fortress
- reduce the impact of game bugs
- give the player more agency and control over the game
- provide alternatives to toilsome or frustrating aspects of gameplay
- make the game more fun
The DFHack team members (and our primary roles and pronouns) are:
- Lethosor (team lead, he/him)
- myk002 (developer, community lead, he/him)
- ab9rf (reverse engineer, she/her)
- Quietust (reverse engineer, he/him)
- BenLubar (operations engineer, any/all)
DFHack also includes contributions from hundreds upon hundreds of community members! The best ways to interact with us are on the DFHack Discord or by filing issues on GitHub. Community contributions to DFHack are very welcome, both for the documentation and for the code. Come talk with us! We are happy to help get you oriented with the development process.
Announcements
DFHack is now available on Steam!, PSAs
DFHack is now available on Steam!
For those who play Dwarf Fortress on Steam, you can now install DFHack through Steam as well! This has the added benefit of letting Steam auto-update DFHack for you. Instead of installing DFHack manually, head over to our Steam page and add DFHack to your library. If you have multiple drives or Steam Library folders, you will need to ensure DFHack is installed to the same location Dwarf Fortress is.
If you'd like to get new DFHack bugfixes and features first and are willing to file GitHub issues for any problems you encounter, please consider subscribing to the beta release channel. We will be depending on beta subscriber feedback to help shape new feature development. Also, by testing the pre-release builds of DFHack, you are helping us make high-quality stable releases. To subscribe to the beta channel, right click on the DFHack app in your steam client, go to Properties, select Betas, and change the dropdown from "None" to "beta - Beta release channel". Thank you! We really appreciate your help with this!
Bringing DFHack to Steam as an official mod was a massive undertaking. We'd like to thank everyone who helped make this happen:
- Graphic Design: TaxiService, RafaelKB, Rumrusher
- Steam installation, Steam Deck, and stability testing: AndrielChaoti, Finn!, Robob27, Thalzen, esotericist, TaxiService, Ozzatron, sdegrace, 20k, plule, RafaelKB, Putnam, drhead, Scootieloo, coskerstrike, and 200+ community members on Reddit and elsewhere
Special thanks go out to Kitfox for fielding Steam's questions about DFHack during the build review process, approving us as a community-written DF mod, and working with us every step of the way. You're awesome!
And, of course, a big thank you to Zach and Tarn, without whom we all wouldn't be here, and Putnam, who has had such a large impact on DF already in the short time she's been working with Bay 12.
PSAs
As always, remember that, just like the vanilla DF game, DFHack tools can also have bugs. It is a good idea to save often and keep backups of the forts that you care about.
Many DFHack tools that worked in previous (pre-Steam) versions of DF have not been updated yet and are marked with the "unavailable" tag in their docs. If you try to run them, they will show a warning and exit immediately. You can run the command again to override the warning (though of course the tools may not work). We make no guarantees of reliability for the tools that are marked as "unavailable".
The in-game interface for running DFHack commands (gui/launcher
) will not show "unavailable" tools by default. You can still run them if you know their names, or you can turn on dev mode by hitting Ctrl-D while in gui/launcher
and they will be added to the autocomplete list. Some tools do not compile yet and are not available at all, even when in dev mode.
If you see a tool complaining about the lack of a cursor, know that it's referring to the keyboard cursor (which used to be the only real option in Dwarf Fortress). You can enable the keyboard cursor in the DF settings, and you can show it by entering mining mode or selecting the dump/forbid tool. We're working on making DFHack tools more mouse-aware and accessible.
Highlights
Usability improvements, buildingplan, gui/civ-alert, gui/design, mod support
There have been significant advancements since our last stable release (for 0.47.05) last year. Here's a selection of highlights from the top of the top:
Usability improvements
Read the Quickstart guide to get oriented:
Browse and run DFHack tools from the launcher:
Enable the general strike bug fix in gui/control-panel
:
There's a lot to talk about here! DFHack now has a fully-functional windowing system, where DFHack tool windows can be dragged, resized, and focused/unfocused for keyboard input. There are also new in-game UIs for discovering and managing DFHack tools and features. gui/launcher
gives you access to all DFHack tools, with autocomplete and in-game help text (with examples for each command!). gui/control-panel
is your one shop shop for toggling DFHack features and setting preferences. The DFHack logo in the upper left corner of the screen gives you quick access to tools associated with the current game context.
Hover the mouse over the DFHack logo and select the Quickstart Guide for a quick walkthrough about how to use DFHack in DF. You can also read the guide online.
Buildingplan
Easily plan out buildings before you have materials with buildingplan
:
DFHack's buildingplan plugin allows you to place furniture, constructions, and other buildings, regardless of whether the required materials are available. This allows you to focus purely on design elements when you are laying out your fort, and defer item production concerns to a more convenient time. It monitors your stocks of available building materials and attaches new items to the buildings so they can be built. You can set filters on your building materials to be sure that when items are attached, they meet your specific needs. For example, you can plan out walls that are guaranteed to be a consistent color and screw pumps that are guaranteed to be magma safe.
gui/civ-alert
Keep your civilians safe during sieges:
In vanilla DF, assigning a unit to a burrow is treated more like a suggestion than a command. This can be frustra...
DFHack 50.07-beta2
This release is compatible with all distributions of DF: Steam, Itch, and Classic.
To download DFHack: scroll down to "Assets" and download the "dfhack-50.07-beta2-Windows-64bit.zip" file.
Please report any bugs (or feature requests) on the DFHack GitHub issue tracker.
Announcements
DFHack is coming to Steam, PSAs
DFHack is coming to Steam
In two weeks, you'll be able to install DFHack from Steam. You may have heard that DFHack now has a Steam page. We're in the mandatory 2 week waiting period right now before we can go live, but in two weeks, Steam users will be able to keep DFHack updated via Steam instead of having to go through the manual install process for every version.
This was a massive undertaking, and thanks to everyone who helped make this happen: TaxiService, RafaelKB, and Rumrusher for graphic design; AndrielChaoti, Finn!, Robob27, Thalzen, esotericist, TaxiService, Ozzatron, sdegrace, 20k, plule, RafaelKB, Putnam, drhead, Scootieloo, and coskerstrike for beta testing the Steam release process; and, of course, Kitfox for fielding Steam's questions during the build review and approving us as a DF mod : )
PSAs
As always, remember that, just like the vanilla DF game, DFHack tools can also have bugs. It is a good idea to save often and keep backups of the forts that you care about.
Many DFHack tools that worked in previous (pre-Steam) versions of DF have not been tested thoroughly with the newest versions and have the "unavailable" tag in their docs. If you try to run them, they will show a warning and exit immediately. You can run the command again to override the warning (though of course the tools may not work). We make no guarantees of reliability for the tools that are marked as "unavailable".
The in-game interface for running DFHack commands (gui/launcher
) will not show "unavailable" tools by default. You can still run them if you know their names, or you can turn on dev mode by hitting Ctrl-D while in gui/launcher
and they will autocomplete as normal. Some tools do not compile yet and are not available at all, even when in dev mode.
For those of you using sdl12compat, note that you will need to replace the "SDLreal.dll" file that DFHack installs with the SDL.dll (renamed to "SDLreal.dll") from sdl12compat. While we do not specifically recommend using sdl12compat, we have generally heard positive feedback about it.
Steam deck users: To avoid blocking the screen with the DFHack terminal window, please edit the dfhack-config/init/dfhack.init
file and add a line with the word hide
. This will hide the DFHack terminal and get it out of the way. You can show it again if you need it by running the command show
from gui/launcher
.
If you see a tool complaining about the lack of a cursor, know that it's referring to the keyboard cursor (which used to be the only real option in Dwarf Fortress). You can enable the keyboard cursor in the DF settings, and you can show it by entering mining mode or selecting the dump/forbid tool. We're working on making DFHack tools more mouse-aware and accessible.
Highlights
fix/general-strike, gui/civ-alert, buildingplan, tailor, mod support
fix/general-strike
enable the general strike bug fix in gui/control-panel:
This script attempts to fix known causes of the "general strike bug", where dwarves just stop accepting work and stand around with "No job". Big thanks to Putnam for contributing the logic to DFHack so players can benefit before the final fix is added to vanilla DF.
You can enable automatic running of this fix in the "Maintenance" tab of gui/control-panel
.
gui/civ-alert
keep your civilians safe during sieges:
In vanilla DF, assigning a unit to a burrow is treated more like a suggestion than a command. This can be frustrating when you're assigning units to burrows in order to get them out of danger. In contrast, triggering a civilian alert with gui/civ-alert
will cause all your non-military citizens to immediately rush to a burrow ASAP and stay there. No need to manually assign your civilians to the burrow, the alert applies to all civilians automatically. This gives you a way to keep your civilians safe when there is danger about.
You'll notice an extra panel on the Squads menu (the one that shows up on the right side of the screen when you hit q
) that prompts you to configure a burrow to use for the civ alert. Get it set up, and when danger comes a-knockin', hit that Big Red Button!
Buildingplan
More bugs squashed in buildingplan, notably:
- Issues with filter settings getting lost on game load have been solved
- All stairs types will now properly use the filter you set for stairs, and the shape of the staircase will now take carved staircases that you might be building over into account
Also, the final feature from the old automaterial
plugin has been added to buildingplan
: if you are choosing your materials manually when you build, you can configure the building type to automatically use the last material you selected until it is all gone. No need to click through the Choose Items dialog.
Expect further improvements to the buildingplan
UI in upcoming releases!
Tailor
The tailor plugin has received some love this cycle, with better detection routines for which units need which types of clothing. This leads to more accurate manager orders to produce clothes in correct quantities. Turn tailor
on in gui/control-panel
and give it a try if you haven't already!
Support for scripts in DF mods
Whaaaat?? Yes, it's true. Scripts with mods now work automatically as soon as you activate them for a world. No more manual copying of scripts after "installation". This allows everything from single scripts to total conversion mods that add new scripted gameplay elements to work seamlessly, straight from the DF Steam Workshop. See the DFHack modding guide for details. You can also subscribe to the example Workshop mod to see a real example of how to distribute scripts via Steam Workshop (though the format is applicable to mods distributed by non-Steam means as well).
Generated Release Notes
New tools, fixes, and improvements
New Plugins
getplants
: designate trees for chopping and shrubs for gathering according to typeprospector
: get stone, ore, gem, and other tile property counts in fort mode. embark site estimates are not yet available.
New Scripts
fix/general-strike
: fix known causes of the general strike bug (contributed by Putnam)gui/civ-alert
: configure and trigger civilian alertsgui/seedwatch
: GUI config and status panel interface forseedwatch
Fixes
buildingplan
:- filters are now properly applied to planned stairs
- existing carved up/down stairs are now taken into account when determining which stair shape to construct
- upright spike traps are now placed extended rather than retracted
- you can no longer designate constructions on tiles with magma or deep water, mirroring the vanilla restrictions
- fixed material filters getting lost for planning buildings on save/reload
- respect building size limits (e.g. roads and bridges cannot be more than 31 tiles in any dimension)
caravan
: item list length now correct when expanding and collapsing containersprioritize
: fixed all watched job type names showing asnil
after a game loadsuspendmanager
:- does not suspend non-blocking jobs such as floor bars or bridges anymore
- fix occasional bad identification of buildingplan jobs
tailor
:- properly discriminate between dyed and undyed cloth
- no longer default to using adamantine cloth for producing clothes
- take queued orders into account when calculating available materials
- skip units who can't wear clothes
- identify more available items as available, solving issues with over-production
warn-starving
: no longer warns for enemy and neutral units
Misc Improvements
- scripts in
data/installed mods/
subfolders are now automatically added to the DFHack script path. DFHack recognizes two directories in a mod's folder:scripts_modinstalled/
andscripts_modactive/
.scripts_modinstalled/
folders will always be added the script path, regardl...