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 ++++++++++++++++++++++ .../nea/notenoughupdates/features/NEUFeature.kt | 16 ++++++++++ .../notenoughupdates/features/world/FairySouls.kt | 12 ++++++++ 3 files changed, 64 insertions(+) create mode 100644 src/main/kotlin/moe/nea/notenoughupdates/features/FeatureManager.kt create mode 100644 src/main/kotlin/moe/nea/notenoughupdates/features/NEUFeature.kt create mode 100644 src/main/kotlin/moe/nea/notenoughupdates/features/world/FairySouls.kt (limited to 'src/main/kotlin/moe/nea/notenoughupdates/features') 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() + } + +} diff --git a/src/main/kotlin/moe/nea/notenoughupdates/features/NEUFeature.kt b/src/main/kotlin/moe/nea/notenoughupdates/features/NEUFeature.kt new file mode 100644 index 0000000..1d3628e --- /dev/null +++ b/src/main/kotlin/moe/nea/notenoughupdates/features/NEUFeature.kt @@ -0,0 +1,16 @@ +package moe.nea.notenoughupdates.features + +interface NEUFeature { + val name: String + val identifier: String + val defaultEnabled: Boolean + get() = true + var isEnabled: Boolean + get() = FeatureManager.isEnabled(identifier) ?: defaultEnabled + set(value) { + FeatureManager.setEnabled(identifier, value) + } + + fun onLoad() + +} diff --git a/src/main/kotlin/moe/nea/notenoughupdates/features/world/FairySouls.kt b/src/main/kotlin/moe/nea/notenoughupdates/features/world/FairySouls.kt new file mode 100644 index 0000000..b928f3d --- /dev/null +++ b/src/main/kotlin/moe/nea/notenoughupdates/features/world/FairySouls.kt @@ -0,0 +1,12 @@ +package moe.nea.notenoughupdates.features.world + +import moe.nea.notenoughupdates.features.NEUFeature + +object FairySouls : NEUFeature { + override val name: String get() = "Fairy Souls" + override val identifier: String get() = "fairy-souls" + + override fun onLoad() { + + } +} -- cgit