From 3743ae88d94c02660046d79b67c76d5bce6cdcc1 Mon Sep 17 00:00:00 2001 From: Linnea Gräf Date: Sun, 4 May 2025 14:18:24 +0200 Subject: feat: Add *base64 and *json nbt path matchers --- src/main/kotlin/util/Base64Util.kt | 7 +++++++ .../predicates/ExtraAttributesPredicate.kt | 20 +++++++++++++++++++- 2 files changed, 26 insertions(+), 1 deletion(-) (limited to 'src') diff --git a/src/main/kotlin/util/Base64Util.kt b/src/main/kotlin/util/Base64Util.kt index 44bcdfd..c39c601 100644 --- a/src/main/kotlin/util/Base64Util.kt +++ b/src/main/kotlin/util/Base64Util.kt @@ -1,7 +1,14 @@ package moe.nea.firmament.util +import java.util.Base64 + object Base64Util { + fun decodeString(str: String): String { + return Base64.getDecoder().decode(str.padToValidBase64()) + .decodeToString() + } + fun String.padToValidBase64(): String { val align = this.length % 4 if (align == 0) return this diff --git a/src/texturePacks/java/moe/nea/firmament/features/texturepack/predicates/ExtraAttributesPredicate.kt b/src/texturePacks/java/moe/nea/firmament/features/texturepack/predicates/ExtraAttributesPredicate.kt index 6fea1c3..bcf2eaf 100644 --- a/src/texturePacks/java/moe/nea/firmament/features/texturepack/predicates/ExtraAttributesPredicate.kt +++ b/src/texturePacks/java/moe/nea/firmament/features/texturepack/predicates/ExtraAttributesPredicate.kt @@ -1,10 +1,12 @@ - package moe.nea.firmament.features.texturepack.predicates +import com.google.gson.Gson import com.google.gson.JsonArray import com.google.gson.JsonElement import com.google.gson.JsonObject import com.google.gson.JsonPrimitive +import com.mojang.serialization.JsonOps +import kotlin.jvm.optionals.getOrDefault import moe.nea.firmament.features.texturepack.FirmamentModelPredicate import moe.nea.firmament.features.texturepack.FirmamentModelPredicateParser import moe.nea.firmament.features.texturepack.StringMatcher @@ -17,8 +19,10 @@ import net.minecraft.nbt.NbtFloat import net.minecraft.nbt.NbtInt import net.minecraft.nbt.NbtList import net.minecraft.nbt.NbtLong +import net.minecraft.nbt.NbtOps import net.minecraft.nbt.NbtShort import net.minecraft.nbt.NbtString +import moe.nea.firmament.util.Base64Util import moe.nea.firmament.util.extraAttributes fun interface NbtMatcher { @@ -261,6 +265,20 @@ class NbtPrism(val path: List) { var switch = mutableListOf() for (pathSegment in path) { if (pathSegment == ".") continue + if (pathSegment != "*" && pathSegment.startsWith("*")) { + if (pathSegment == "*json") { + for (element in rootSet) { + val eString = element.asString() ?: continue + val element = Gson().fromJson(eString, JsonElement::class.java) + switch.add(JsonOps.INSTANCE.convertTo(NbtOps.INSTANCE, element)) + } + } else if (pathSegment == "*base64") { + for (element in rootSet) { + val string = element.asString() ?: continue + switch.add(NbtString.of(Base64Util.decodeString(string))) + } + } + } for (element in rootSet) { if (element is NbtList) { if (pathSegment == "*") -- cgit