mirror of
https://github.com/yairm210/Unciv.git
synced 2025-01-22 02:07:43 +07:00
Allow filters in the ModOptions "ToRemove" lists (#8730)
* Allow "*" wildcard in the ModOptions "ToRemove" lists * Allow filters in the ModOptions "ToRemove" lists
This commit is contained in:
parent
33ddb2dc3a
commit
5d07fd981b
@ -120,34 +120,53 @@ class Ruleset {
|
||||
|
||||
fun add(ruleset: Ruleset) {
|
||||
beliefs.putAll(ruleset.beliefs)
|
||||
ruleset.modOptions.buildingsToRemove
|
||||
.flatMap { buildingToRemove ->
|
||||
buildings.filter { it.value.matchesFilter(buildingToRemove) }.keys
|
||||
}.toSet().forEach {
|
||||
buildings.remove(it)
|
||||
}
|
||||
buildings.putAll(ruleset.buildings)
|
||||
for (buildingToRemove in ruleset.modOptions.buildingsToRemove) buildings.remove(
|
||||
buildingToRemove
|
||||
)
|
||||
difficulties.putAll(ruleset.difficulties)
|
||||
eras.putAll(ruleset.eras)
|
||||
speeds.putAll(ruleset.speeds)
|
||||
globalUniques = GlobalUniques().apply {
|
||||
uniques.addAll(globalUniques.uniques); uniques.addAll(ruleset.globalUniques.uniques)
|
||||
uniques.addAll(globalUniques.uniques)
|
||||
uniques.addAll(ruleset.globalUniques.uniques)
|
||||
}
|
||||
ruleset.modOptions.nationsToRemove
|
||||
.flatMap { nationToRemove ->
|
||||
nations.filter { it.value.matchesFilter(nationToRemove) }.keys
|
||||
}.toSet().forEach {
|
||||
nations.remove(it)
|
||||
}
|
||||
nations.putAll(ruleset.nations)
|
||||
for (nationToRemove in ruleset.modOptions.nationsToRemove) nations.remove(nationToRemove)
|
||||
policyBranches.putAll(ruleset.policyBranches)
|
||||
policies.putAll(ruleset.policies)
|
||||
quests.putAll(ruleset.quests)
|
||||
religions.addAll(ruleset.religions)
|
||||
ruinRewards.putAll(ruleset.ruinRewards)
|
||||
specialists.putAll(ruleset.specialists)
|
||||
ruleset.modOptions.techsToRemove
|
||||
.flatMap { techToRemove ->
|
||||
technologies.filter { it.value.matchesFilter(techToRemove) }.keys
|
||||
}.toSet().forEach {
|
||||
technologies.remove(it)
|
||||
}
|
||||
technologies.putAll(ruleset.technologies)
|
||||
for (techToRemove in ruleset.modOptions.techsToRemove) technologies.remove(techToRemove)
|
||||
terrains.putAll(ruleset.terrains)
|
||||
tileImprovements.putAll(ruleset.tileImprovements)
|
||||
tileResources.putAll(ruleset.tileResources)
|
||||
units.putAll(ruleset.units)
|
||||
unitTypes.putAll(ruleset.unitTypes)
|
||||
victories.putAll(ruleset.victories)
|
||||
cityStateTypes.putAll(ruleset.cityStateTypes)
|
||||
for (unitToRemove in ruleset.modOptions.unitsToRemove) units.remove(unitToRemove)
|
||||
ruleset.modOptions.unitsToRemove
|
||||
.flatMap { unitToRemove ->
|
||||
units.filter { it.value.matchesFilter(unitToRemove) }.keys
|
||||
}.toSet().forEach {
|
||||
units.remove(it)
|
||||
}
|
||||
units.putAll(ruleset.units)
|
||||
modOptions.uniques.addAll(ruleset.modOptions.uniques)
|
||||
modOptions.constants.merge(ruleset.modOptions.constants)
|
||||
|
||||
@ -565,7 +584,7 @@ object RulesetCache : HashMap<String,Ruleset>() {
|
||||
|
||||
for (mod in loadedMods.sortedByDescending { it.modOptions.isBaseRuleset }) {
|
||||
if (mod.modOptions.isBaseRuleset) {
|
||||
// This is so we don't keep using the base ruleset's unqiues *by reference* and add to in ad infinitum
|
||||
// This is so we don't keep using the base ruleset's uniques *by reference* and add to in ad infinitum
|
||||
newRuleset.modOptions.uniques = ArrayList()
|
||||
newRuleset.modOptions.isBaseRuleset = true
|
||||
}
|
||||
|
@ -295,7 +295,17 @@ import kotlin.math.pow
|
||||
}
|
||||
|
||||
fun getContrastRatio() = getContrastRatio(getInnerColor(), getOuterColor())
|
||||
}
|
||||
|
||||
fun matchesFilter(filter: String): Boolean {
|
||||
return when (filter) {
|
||||
"All" -> true
|
||||
name -> true
|
||||
"Major" -> isMajorCiv()
|
||||
"CityState" -> isCityState()
|
||||
else -> uniques.contains(filter)
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
/** All defined by https://www.w3.org/TR/WCAG20/#relativeluminancedef */
|
||||
|
@ -1,7 +1,6 @@
|
||||
package com.unciv.models.ruleset.tech
|
||||
|
||||
import com.unciv.GUI
|
||||
import com.unciv.UncivGame
|
||||
import com.unciv.logic.civilization.Civilization
|
||||
import com.unciv.models.ruleset.Building
|
||||
import com.unciv.models.ruleset.Ruleset
|
||||
@ -285,4 +284,13 @@ class Technology: RulesetObject() {
|
||||
|
||||
return lineList
|
||||
}
|
||||
|
||||
fun matchesFilter(filter: String): Boolean {
|
||||
return when (filter) {
|
||||
"All" -> true
|
||||
name -> true
|
||||
era() -> true
|
||||
else -> uniques.contains(filter)
|
||||
}
|
||||
}
|
||||
}
|
||||
|
@ -96,6 +96,18 @@ It can be any value noted in `baseUnitFilter` or one of the following:
|
||||
- `Barbarians`, `Barbarian`
|
||||
- Again, any combination of the above is also allowed, e.g. `[{Wounded} {Water}]` units.
|
||||
|
||||
## nationFilter
|
||||
|
||||
At the moment only implemented for [ModOptions.nationsToRemove](../Other/Miscellaneous-JSON-files.md#modoptionsjson).
|
||||
|
||||
Allowed values are:
|
||||
|
||||
- `All`
|
||||
- `Major`
|
||||
- `CityState`
|
||||
- The name of a Nation
|
||||
- A unique a Nation has (verbatim, no placeholders)
|
||||
|
||||
## populationFilter
|
||||
|
||||
A filter determining a part of the population of a city. It can be any of the following values:
|
||||
@ -133,6 +145,17 @@ For example: `+1 Science`.
|
||||
|
||||
These can be strung together with ", " between them, for example: `+2 Production, +3 Food`.
|
||||
|
||||
## technologyFilter
|
||||
|
||||
At the moment only implemented for [ModOptions.techsToRemove](../Other/Miscellaneous-JSON-files.md#modoptionsjson).
|
||||
|
||||
Allowed values are:
|
||||
|
||||
- `All`
|
||||
- The name of an Era
|
||||
- The name of a Technology
|
||||
- A unique a Technology has (verbatim, no placeholders)
|
||||
|
||||
## terrainFilter
|
||||
|
||||
This indicates the terrain on a single tile. The following values are allowed:
|
||||
|
@ -109,14 +109,14 @@ This file is a little different:
|
||||
The file can have the following attributes, including the values Unciv sets (no point in a mod author setting those):
|
||||
|
||||
| Attribute | Type | Optional | Notes |
|
||||
| --------- | ---- | -------- | ----- |
|
||||
|---------------------|---------|----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|
||||
| isBaseRuleset | Boolean | false | Differentiates mods that change the vanilla ruleset or replace it |
|
||||
| maxXPfromBarbarians | Integer | 30 | *Deprecated*, see [constants](#ModConstants) |
|
||||
| uniques | List | empty | Mod-wide specials, [see here](../Modders/uniques.md#modoptions-uniques) |
|
||||
| techsToRemove | List | empty | List of [Technologies](Civilization-related-JSON-files.md#techsjson) to remove (isBaseRuleset=false only) |
|
||||
| buildingsToRemove | List | empty | List of [Buildings or Wonders](Civilization-related-JSON-files.md#buildingsjson) to remove (isBaseRuleset=false only) |
|
||||
| unitsToRemove | List | empty | List of [Units](Unit-related-JSON-files.md#unitsjson) to remove (isBaseRuleset=false only) |
|
||||
| nationsToRemove | List | empty | List of [Nations](Civilization-related-JSON-files.md#nationsjson) to remove (isBaseRuleset=false only) |
|
||||
| techsToRemove | List | empty | List of [Technologies](Civilization-related-JSON-files.md#techsjson) or [-filters](../Modders/Unique-parameters.md#technologyfilter) to remove (isBaseRuleset=false only) |
|
||||
| buildingsToRemove | List | empty | List of [Buildings or Wonders](Civilization-related-JSON-files.md#buildingsjson) or [-filters](../Modders/Unique-parameters.md#buildingfilter) to remove (isBaseRuleset=false only) |
|
||||
| unitsToRemove | List | empty | List of [Units](Unit-related-JSON-files.md#unitsjson) or [-filters](../Modders/Unique-parameters.md#baseunitfilter) to remove (isBaseRuleset=false only) |
|
||||
| nationsToRemove | List | empty | List of [Nations](Civilization-related-JSON-files.md#nationsjson) or [-filters](../Modders/Unique-parameters.md#nationfilter) to remove (isBaseRuleset=false only) |
|
||||
| lastUpdated | String | empty | Set automatically after download - Last repository update, not necessarily last content change |
|
||||
| modUrl | String | empty | Set automatically after download - URL of repository |
|
||||
| author | String | empty | Set automatically after download - Owner of repository |
|
||||
@ -192,7 +192,7 @@ The formula for the gold cost of a unit upgrade is (rounded down to a multiple o
|
||||
( max((`base` + `perProduction` * (new_unit_cost - old_unit_cost)), 0)
|
||||
* (1 + eraNumber * `eraMultiplier`) * `civModifier`
|
||||
) ^ `exponent`
|
||||
With `civModifier` being the multiplicative aggregate of ["\[relativeAmount\]% Gold cost of upgrading"](../uniques.md#global_uniques) uniques that apply.
|
||||
With `civModifier` being the multiplicative aggregate of ["\[relativeAmount\]% Gold cost of upgrading"](../Modders/uniques.md#global-uniques) uniques that apply.
|
||||
|
||||
|
||||
## VictoryTypes.json
|
||||
|
Loading…
Reference in New Issue
Block a user