mirror of
https://github.com/yairm210/Unciv.git
synced 2025-01-07 14:02:48 +07:00
Resolved #9908 - Improvements created by buildings can activate 'take over adjacent tiles' unique
This commit is contained in:
parent
42a5440a76
commit
c1da217ff6
@ -9,7 +9,6 @@ import com.unciv.logic.civilization.AlertType
|
|||||||
import com.unciv.logic.civilization.NotificationCategory
|
import com.unciv.logic.civilization.NotificationCategory
|
||||||
import com.unciv.logic.civilization.NotificationIcon
|
import com.unciv.logic.civilization.NotificationIcon
|
||||||
import com.unciv.logic.civilization.PopupAlert
|
import com.unciv.logic.civilization.PopupAlert
|
||||||
import com.unciv.logic.map.mapunit.UnitTurnManager
|
|
||||||
import com.unciv.logic.map.tile.Tile
|
import com.unciv.logic.map.tile.Tile
|
||||||
import com.unciv.logic.multiplayer.isUsersTurn
|
import com.unciv.logic.multiplayer.isUsersTurn
|
||||||
import com.unciv.models.ruleset.Building
|
import com.unciv.models.ruleset.Building
|
||||||
@ -32,7 +31,6 @@ import com.unciv.ui.components.extensions.withItem
|
|||||||
import com.unciv.ui.components.extensions.withoutItem
|
import com.unciv.ui.components.extensions.withoutItem
|
||||||
import com.unciv.ui.screens.civilopediascreen.CivilopediaCategories
|
import com.unciv.ui.screens.civilopediascreen.CivilopediaCategories
|
||||||
import com.unciv.ui.screens.civilopediascreen.FormattedLine
|
import com.unciv.ui.screens.civilopediascreen.FormattedLine
|
||||||
import com.unciv.ui.screens.worldscreen.unit.actions.UnitActions
|
|
||||||
import kotlin.math.ceil
|
import kotlin.math.ceil
|
||||||
import kotlin.math.min
|
import kotlin.math.min
|
||||||
import kotlin.math.roundToInt
|
import kotlin.math.roundToInt
|
||||||
@ -774,14 +772,13 @@ class CityConstructions : IsPartOfGameInfoSerialization {
|
|||||||
* If [building] is an improvement-creating one, find a marked tile matching the improvement to be created
|
* If [building] is an improvement-creating one, find a marked tile matching the improvement to be created
|
||||||
* (skip if none found), then un-mark the tile and place the improvement unless [removeOnly] is set.
|
* (skip if none found), then un-mark the tile and place the improvement unless [removeOnly] is set.
|
||||||
*/
|
*/
|
||||||
fun applyCreateOneImprovement(building: Building, removeOnly: Boolean = false) {
|
private fun applyCreateOneImprovement(building: Building, removeOnly: Boolean = false) {
|
||||||
val improvement = building.getImprovementToCreate(city.getRuleset())
|
val improvement = building.getImprovementToCreate(city.getRuleset())
|
||||||
?: return
|
?: return
|
||||||
val tileForImprovement = getTileForImprovement(improvement.name) ?: return
|
val tileForImprovement = getTileForImprovement(improvement.name) ?: return
|
||||||
tileForImprovement.stopWorkingOnImprovement() // clears mark
|
tileForImprovement.stopWorkingOnImprovement() // clears mark
|
||||||
if (removeOnly) return
|
if (removeOnly) return
|
||||||
/**todo unify with [UnitActions.getImprovementConstructionActions] and [UnitTurnManager.workOnImprovement] - this won't allow e.g. a building to place a road */
|
tileForImprovement.changeImprovement(improvement.name, city.civ)
|
||||||
tileForImprovement.changeImprovement(improvement.name)
|
|
||||||
city.civ.lastSeenImprovement[tileForImprovement.position] = improvement.name
|
city.civ.lastSeenImprovement[tileForImprovement.position] = improvement.name
|
||||||
// If bought the worldscreen will not have been marked to update, and the new improvement won't show until later...
|
// If bought the worldscreen will not have been marked to update, and the new improvement won't show until later...
|
||||||
GUI.setUpdateWorldOnNextRender()
|
GUI.setUpdateWorldOnNextRender()
|
||||||
|
Loading…
Reference in New Issue
Block a user