From 2d02e69d246c9ff83760a1fc522619233391e442 Mon Sep 17 00:00:00 2001 From: SomeTroglodyte <63000004+SomeTroglodyte@users.noreply.github.com> Date: Mon, 5 Jun 2023 18:04:27 +0200 Subject: [PATCH] Mod checks against sellable, missing or multiple Palace(s) (#9516) * Mod checks against sellable, missing or multiple Palace(s) * Fix Studio adding quotes unasked --- .../src/com/unciv/models/ruleset/RulesetValidator.kt | 12 ++++++++++-- 1 file changed, 10 insertions(+), 2 deletions(-) diff --git a/core/src/com/unciv/models/ruleset/RulesetValidator.kt b/core/src/com/unciv/models/ruleset/RulesetValidator.kt index 53f74ea985..221de610e4 100644 --- a/core/src/com/unciv/models/ruleset/RulesetValidator.kt +++ b/core/src/com/unciv/models/ruleset/RulesetValidator.kt @@ -62,8 +62,10 @@ class RulesetValidator(val ruleset: Ruleset) { UniqueType.Unbuildable)) lines += "${building.name} is buildable and therefore must either have an explicit cost or reference an existing tech!" - checkUniques(building, lines, rulesetInvariant, tryFixUnknownUniques) + if (building.hasUnique(UniqueType.IndicatesCapital) && !building.isAnyWonder() && !building.hasUnique(UniqueType.Unsellable)) + lines += "${building.name} is a Capital indicator and therefore must either be a wonder or explicitly marked 'Unsellable'!" + checkUniques(building, lines, rulesetInvariant, tryFixUnknownUniques) } for (nation in ruleset.nations.values) { @@ -181,6 +183,12 @@ class RulesetValidator(val ruleset: Ruleset) { checkUniques(unit, lines, rulesetSpecific, tryFixUnknownUniques) } + when (ruleset.buildings.values.count { it.hasUnique(UniqueType.IndicatesCapital) }) { + 0 -> lines += "No building indicating the Capital in ruleset!" + 1 -> Unit + else -> lines.add("There is more than one building indicating the Capital in the ruleset!", RulesetErrorSeverity.Warning) + } + for (building in ruleset.buildings.values) { if (building.requiredTech != null && !ruleset.technologies.containsKey(building.requiredTech!!)) lines += "${building.name} requires tech ${building.requiredTech} which does not exist!" @@ -336,7 +344,7 @@ class RulesetValidator(val ruleset: Ruleset) { for (nation in ruleset.nations.values) { checkUniques(nation, lines, rulesetSpecific, tryFixUnknownUniques) - if (nation.cityStateType!=null && nation.cityStateType !in ruleset.cityStateTypes) + if (nation.cityStateType != null && nation.cityStateType !in ruleset.cityStateTypes) lines += "${nation.name} is of city-state type ${nation.cityStateType} which does not exist!" if (nation.favoredReligion != null && nation.favoredReligion !in ruleset.religions) lines += "${nation.name} has ${nation.favoredReligion} as their favored religion, which does not exist!"