From a12b9b5e6fd3c9c2fa70204f5710692e4376a01e Mon Sep 17 00:00:00 2001 From: Duan Tao Date: Fri, 3 Jul 2020 20:48:28 +0800 Subject: [PATCH] AI destroys empty barbarian encampment. (#2793) --- .../unciv/logic/automation/UnitAutomation.kt | 17 +++++++++-------- 1 file changed, 9 insertions(+), 8 deletions(-) diff --git a/core/src/com/unciv/logic/automation/UnitAutomation.kt b/core/src/com/unciv/logic/automation/UnitAutomation.kt index 976c104920..a4986cce94 100644 --- a/core/src/com/unciv/logic/automation/UnitAutomation.kt +++ b/core/src/com/unciv/logic/automation/UnitAutomation.kt @@ -25,7 +25,7 @@ object UnitAutomation { } internal fun tryExplore(unit: MapUnit): Boolean { - if (tryGoToRuin(unit) && unit.currentMovement == 0f) return true + if (tryGoToRuinAndEncampment(unit) && unit.currentMovement == 0f) return true val explorableTilesThisTurn = unit.movement.getDistanceToTiles().keys.filter { isGoodTileToExplore(unit, it) } @@ -46,16 +46,17 @@ object UnitAutomation { return false } - private fun tryGoToRuin(unit: MapUnit): Boolean { + private fun tryGoToRuinAndEncampment(unit: MapUnit): Boolean { if (!unit.civInfo.isMajorCiv()) return false // barbs don't have anything to do in ruins val unitDistanceToTiles = unit.movement.getDistanceToTiles() - val tileWithRuin = unitDistanceToTiles.keys + val tileWithRuinOrEncampment = unitDistanceToTiles.keys .firstOrNull { - it.improvement == Constants.ancientRuins && unit.movement.canMoveTo(it) + (it.improvement == Constants.ancientRuins || it.improvement == Constants.barbarianEncampment) + && unit.movement.canMoveTo(it) } - if (tileWithRuin == null) + if (tileWithRuinOrEncampment == null) return false - unit.movement.moveToTile(tileWithRuin) + unit.movement.moveToTile(tileWithRuinOrEncampment) return true } @@ -115,7 +116,7 @@ object UnitAutomation { && unit.name in GreatPersonManager().statToGreatPersonMapping.values)// So "Great War Infantry" isn't caught here return SpecificUnitAutomation.automateGreatPerson(unit) - if (tryGoToRuin(unit)) { + if (tryGoToRuinAndEncampment(unit)) { if (unit.currentMovement == 0f) return } @@ -399,7 +400,7 @@ object UnitAutomation { /** This is what a unit with the 'explore' action does. It also explores, but also has other functions, like healing if necessary. */ fun automatedExplore(unit: MapUnit) { - if (tryGoToRuin(unit) && unit.currentMovement == 0f) return + if (tryGoToRuinAndEncampment(unit) && unit.currentMovement == 0f) return if (unit.health < 80 && tryHealUnit(unit)) return if (tryExplore(unit)) return unit.civInfo.addNotification("[${unit.name}] finished exploring.", unit.currentTile.position, Color.GRAY)