From 7602aa4d0de8fda506562d08416dc45404183196 Mon Sep 17 00:00:00 2001 From: Yair Morgenstern Date: Sun, 4 Jun 2023 13:42:15 +0300 Subject: [PATCH] Fixed great engineer automation trying to reach cities it can't --- .../logic/automation/unit/SpecificUnitAutomation.kt | 13 +++++-------- 1 file changed, 5 insertions(+), 8 deletions(-) diff --git a/core/src/com/unciv/logic/automation/unit/SpecificUnitAutomation.kt b/core/src/com/unciv/logic/automation/unit/SpecificUnitAutomation.kt index 95dbf5fb4f..5da9b47325 100644 --- a/core/src/com/unciv/logic/automation/unit/SpecificUnitAutomation.kt +++ b/core/src/com/unciv/logic/automation/unit/SpecificUnitAutomation.kt @@ -296,18 +296,15 @@ object SpecificUnitAutomation { * of `false` can be interpreted as: the unit doesn't know where to go or is stuck. */ fun speedupWonderConstruction(unit: MapUnit): Boolean { val nearbyCityWithAvailableWonders = unit.civ.cities.filter { city -> - // Maybe it would be nice to make space in the city if there's already some - // other civilian unit in there for whatever reason, but again that seems a lot of - // additional complexity for questionable gain. + // Don't speed up construction in small cities. There's a risk the great + // engineer can't get it done entirely and then it takes forever for the small + // city to finish the rest. + city.population.population >= 3 && (unit.movement.canMoveTo(city.getCenterTile()) || unit.currentTile == city.getCenterTile()) - // Don't speed up construction in small cities. There's a risk the great - // engineer can't get it done entirely and then it takes forever for the small - // city to finish the rest. - && city.population.population >= 3 && getWonderThatWouldBenefitFromBeingSpedUp(city) != null }.mapNotNull { city -> val path = unit.movement.getShortestPath(city.getCenterTile()) - if (path.size <= 5) city to path.size else null + if (path.any() && path.size <= 5) city to path.size else null }.minByOrNull { it.second }?.first if (nearbyCityWithAvailableWonders == null) {