diff --git a/docs/changelog.txt b/docs/changelog.txt index 559d3d6d73d..c99974c98ee 100644 --- a/docs/changelog.txt +++ b/docs/changelog.txt @@ -65,10 +65,12 @@ Template for new versions: ## API - ``Units::assignTrainer``: assign a trainer to a trainable animal +- ``Units::unassignTrainer``: unassign a trainer from an animal ## Lua - ``dfhack.units.isTamable``: return false for invaders to match vanilla logic - ``dfhack.units.assignTrainer``: expose new API to Lua +- ``dfhack.units.unassignTrainer``: expose new API to Lua ## Removed - ``nopause``: functionality has moved to `spectate` diff --git a/docs/dev/Lua API.rst b/docs/dev/Lua API.rst index 6709d72ba5f..aab84c5ec09 100644 --- a/docs/dev/Lua API.rst +++ b/docs/dev/Lua API.rst @@ -1486,10 +1486,11 @@ Units module tile occupancy flags appropriately. Returns true if successful. * ``dfhack.units.assignTrainer(unit[, trainer_id])`` +* ``dfhack.units.unassignTrainer(unit)`` - Assignes a trainer to the specified trainable unit. The trainer ID can be - omitted if "any trainer" is desired. Returns a boolean indicating whether the - operation was successful. + Assignes (or unassigns) a trainer for the specified trainable unit. The + trainer ID can be omitted if "any trainer" is desired. Returns a boolean + indicating whether the operation was successful. * ``dfhack.units.getGeneralRef(unit, type)`` diff --git a/library/include/modules/Units.h b/library/include/modules/Units.h index 8cd69b08a05..b8d93c72b8f 100644 --- a/library/include/modules/Units.h +++ b/library/include/modules/Units.h @@ -177,6 +177,7 @@ DFHACK_EXPORT void setNickname(df::unit *unit, std::string nick); DFHACK_EXPORT df::language_name *getVisibleName(df::unit *unit); DFHACK_EXPORT bool assignTrainer(df::unit *unit, int32_t trainer_id = -1); +DFHACK_EXPORT bool unassignTrainer(df::unit *unit); DFHACK_EXPORT df::identity *getIdentity(df::unit *unit); DFHACK_EXPORT df::nemesis_record *getNemesis(df::unit *unit); diff --git a/library/modules/Units.cpp b/library/modules/Units.cpp index 89fe8c392a3..5d3b77715c4 100644 --- a/library/modules/Units.cpp +++ b/library/modules/Units.cpp @@ -507,6 +507,12 @@ bool Units::assignTrainer(df::unit* unit, int32_t trainer_id) { return true; } +bool Units::unassignTrainer(df::unit* unit) { + CHECK_NULL_POINTER(unit); + return erase_from_vector(plotinfo->equipment.training_assignments, + &df::training_assignment::animal_id, unit->id); +} + // check if creature is domesticated // seems to be the only way to really tell if it's completely safe to autonestbox it (training can revert) bool Units::isDomesticated(df::unit* unit)