From 3b03ff1cc6f1cf92810b67ad8074515d8ccce196 Mon Sep 17 00:00:00 2001 From: Linnea Gräf Date: Sun, 10 Aug 2025 13:43:42 +0200 Subject: feat: Add color matching to text replacers --- .../features/texturepack/TreeishTextReplacer.kt | 40 +++++++++------------- 1 file changed, 16 insertions(+), 24 deletions(-) (limited to 'src/texturePacks/java') diff --git a/src/texturePacks/java/moe/nea/firmament/features/texturepack/TreeishTextReplacer.kt b/src/texturePacks/java/moe/nea/firmament/features/texturepack/TreeishTextReplacer.kt index 0a59451..95c277c 100644 --- a/src/texturePacks/java/moe/nea/firmament/features/texturepack/TreeishTextReplacer.kt +++ b/src/texturePacks/java/moe/nea/firmament/features/texturepack/TreeishTextReplacer.kt @@ -1,17 +1,12 @@ package moe.nea.firmament.features.texturepack -import java.lang.StringBuilder import java.util.regex.Matcher -import kotlinx.serialization.KSerializer +import util.json.CodecSerializer import kotlinx.serialization.Serializable -import kotlinx.serialization.descriptors.SerialDescriptor -import kotlinx.serialization.encoding.Decoder -import kotlinx.serialization.encoding.Encoder -import kotlinx.serialization.json.JsonElement +import net.minecraft.text.Style import net.minecraft.text.Text import net.minecraft.text.TextCodecs import moe.nea.firmament.util.directLiteralStringContent -import moe.nea.firmament.util.json.KJsonOps import moe.nea.firmament.util.transformEachRecursively @Serializable @@ -22,26 +17,12 @@ data class TreeishTextReplacer( @Serializable data class SubPartReplacement( val match: StringMatcher, + val style: @Serializable(StyleSerializer::class) Style?, val replace: @Serializable(TextSerializer::class) Text, ) - object TextSerializer : KSerializer { - override val descriptor: SerialDescriptor - get() = JsonElement.serializer().descriptor - - override fun serialize(encoder: Encoder, value: Text) { - encoder.encodeSerializableValue( - JsonElement.serializer(), - TextCodecs.CODEC.encodeStart(KJsonOps.INSTANCE, value).orThrow - ) - } - - override fun deserialize(decoder: Decoder): Text { - return TextCodecs.CODEC.decode(KJsonOps.INSTANCE, decoder.decodeSerializableValue(JsonElement.serializer())) - .orThrow.first - } - } - + object TextSerializer : CodecSerializer(TextCodecs.CODEC) + object StyleSerializer : CodecSerializer