From ec66c82198fe2d61d699d553c1254f08b43fcc65 Mon Sep 17 00:00:00 2001 From: nea Date: Sat, 10 Sep 2022 03:48:03 +0200 Subject: Move Eventhandling around. I still want to use fabric still "array backed" events, but these here are just a bit easier to use from kotlin. --- .../notenoughupdates/features/FeatureManager.kt | 36 ++++++++++++++++++++++ 1 file changed, 36 insertions(+) create mode 100644 src/main/kotlin/moe/nea/notenoughupdates/features/FeatureManager.kt (limited to 'src/main/kotlin/moe/nea/notenoughupdates/features/FeatureManager.kt') diff --git a/src/main/kotlin/moe/nea/notenoughupdates/features/FeatureManager.kt b/src/main/kotlin/moe/nea/notenoughupdates/features/FeatureManager.kt new file mode 100644 index 0000000..766cf1f --- /dev/null +++ b/src/main/kotlin/moe/nea/notenoughupdates/features/FeatureManager.kt @@ -0,0 +1,36 @@ +package moe.nea.notenoughupdates.features + +import kotlinx.serialization.serializer +import moe.nea.notenoughupdates.NotEnoughUpdates +import moe.nea.notenoughupdates.features.world.FairySouls +import moe.nea.notenoughupdates.util.ConfigHolder + +object FeatureManager : ConfigHolder(serializer(), "features", ::Config) { + data class Config( + val enabledFeatures: MutableMap = mutableMapOf() + ) + + private val features = mutableMapOf() + + fun autoload() { + loadFeature(FairySouls) + } + + fun loadFeature(feature: NEUFeature) { + if (feature.identifier in features) { + NotEnoughUpdates.logger.error("Double registering feature ${feature.identifier}. Ignoring second instance $feature") + return + } + features[feature.identifier] = feature + } + + fun isEnabled(identifier: String): Boolean? = + config.enabledFeatures[identifier] + + + fun setEnabled(identifier: String, value: Boolean) { + config.enabledFeatures[identifier] = value + markDirty() + } + +} -- cgit