diff --git a/core/src/com/unciv/logic/civilization/PolicyManager.kt b/core/src/com/unciv/logic/civilization/PolicyManager.kt index f5f758f4..bff73a66 100644 --- a/core/src/com/unciv/logic/civilization/PolicyManager.kt +++ b/core/src/com/unciv/logic/civilization/PolicyManager.kt @@ -80,6 +80,8 @@ class PolicyManager { for (cityInfo in civInfo.cities) cityInfo.cityStats.update() + + if(!canAdoptPolicy()) shouldOpenPolicyPicker=false } fun endTurn(culture: Int) { diff --git a/core/src/com/unciv/models/gamebasics/Building.kt b/core/src/com/unciv/models/gamebasics/Building.kt index fee1efc0..ea4b700b 100644 --- a/core/src/com/unciv/models/gamebasics/Building.kt +++ b/core/src/com/unciv/models/gamebasics/Building.kt @@ -67,39 +67,6 @@ class Building : NamedStats(), IConstruction{ return infoList.joinToString() } - fun getStats(adoptedPolicies: HashSet): Stats { - val stats = this.clone() - if (adoptedPolicies.contains("Organized Religion") && hashSetOf("Monument", "Temple", "Monastery").contains(name)) - stats.happiness += 1 - - if (adoptedPolicies.contains("Free Religion") && hashSetOf("Monument", "Temple", "Monastery").contains(name)) - stats.culture += 1f - - if (adoptedPolicies.contains("Entrepreneurship") && hashSetOf("Mint", "Market", "Bank", "Stock Market").contains(name)) - stats.science += 1f - - if (adoptedPolicies.contains("Humanism") && hashSetOf("University", "Observatory", "Public School").contains(name)) - stats.science += 1f - - if (adoptedPolicies.contains("Theocracy") && name == "Temple") - percentStatBonus = Stats().apply { gold=10f } - - if (adoptedPolicies.contains("Free Thought") && name == "University") - percentStatBonus!!.science = 50f - - if (adoptedPolicies.contains("Rationalism Complete") && !isWonder && stats.science > 0) - stats.gold += 1f - - if (adoptedPolicies.contains("Constitution") && isWonder) - stats.culture += 2f - - if(adoptedPolicies.contains("Autocracy Complete") && cityStrength>0) - stats.happiness+=1 - - return stats - } - - fun getDescription(forBuildingPickerScreen: Boolean, adoptedPolicies: HashSet): String { val stats = getStats(adoptedPolicies) val stringBuilder = StringBuilder() @@ -138,11 +105,45 @@ class Building : NamedStats(), IConstruction{ if(cityStrength!=0) stringBuilder.appendln("{City strength} +".tr() + cityStrength) if(cityHealth!=0) stringBuilder.appendln("{City health} +".tr() + cityHealth) + if(xpForNewUnits!=0) stringBuilder.appendln("+$xpForNewUnits {XP for new units}".tr()) if (maintenance != 0) stringBuilder.appendln("{Maintenance cost}: $maintenance {Gold}".tr()) return stringBuilder.toString().trim() } + fun getStats(adoptedPolicies: HashSet): Stats { + val stats = this.clone() + if (adoptedPolicies.contains("Organized Religion") && hashSetOf("Monument", "Temple", "Monastery").contains(name)) + stats.happiness += 1 + + if (adoptedPolicies.contains("Free Religion") && hashSetOf("Monument", "Temple", "Monastery").contains(name)) + stats.culture += 1f + + if (adoptedPolicies.contains("Entrepreneurship") && hashSetOf("Mint", "Market", "Bank", "Stock Market").contains(name)) + stats.science += 1f + + if (adoptedPolicies.contains("Humanism") && hashSetOf("University", "Observatory", "Public School").contains(name)) + stats.science += 1f + + if (adoptedPolicies.contains("Theocracy") && name == "Temple") + percentStatBonus = Stats().apply { gold=10f } + + if (adoptedPolicies.contains("Free Thought") && name == "University") + percentStatBonus!!.science = 50f + + if (adoptedPolicies.contains("Rationalism Complete") && !isWonder && stats.science > 0) + stats.gold += 1f + + if (adoptedPolicies.contains("Constitution") && isWonder) + stats.culture += 2f + + if(adoptedPolicies.contains("Autocracy Complete") && cityStrength>0) + stats.happiness+=1 + + return stats + } + + override fun getProductionCost(adoptedPolicies: HashSet): Int { return if (!isWonder && culture != 0f && adoptedPolicies.contains("Piety")) (cost * 0.85).toInt() else cost