Make trackedDataToJson more robust

This commit is contained in:
Ryan 2022-07-21 02:47:42 -07:00
parent 682f73bda8
commit e0b371d23c

View file

@ -2,9 +2,7 @@ package dev._00a.valence_extractor;
import com.google.gson.*; import com.google.gson.*;
import net.fabricmc.api.ModInitializer; import net.fabricmc.api.ModInitializer;
import net.minecraft.block.BlockState;
import net.minecraft.entity.Entity; import net.minecraft.entity.Entity;
import net.minecraft.entity.EntityPose;
import net.minecraft.entity.EntityStatuses; import net.minecraft.entity.EntityStatuses;
import net.minecraft.entity.EntityType; import net.minecraft.entity.EntityType;
import net.minecraft.entity.data.DataTracker; import net.minecraft.entity.data.DataTracker;
@ -13,11 +11,9 @@ import net.minecraft.entity.data.TrackedDataHandlerRegistry;
import net.minecraft.entity.passive.CatVariant; import net.minecraft.entity.passive.CatVariant;
import net.minecraft.entity.passive.FrogVariant; import net.minecraft.entity.passive.FrogVariant;
import net.minecraft.item.ItemStack; import net.minecraft.item.ItemStack;
import net.minecraft.nbt.NbtCompound;
import net.minecraft.particle.ParticleEffect; import net.minecraft.particle.ParticleEffect;
import net.minecraft.text.Text; import net.minecraft.text.Text;
import net.minecraft.util.math.BlockPos; import net.minecraft.util.math.BlockPos;
import net.minecraft.util.math.Direction;
import net.minecraft.util.math.EulerAngle; import net.minecraft.util.math.EulerAngle;
import net.minecraft.util.math.GlobalPos; import net.minecraft.util.math.GlobalPos;
import net.minecraft.util.registry.Registry; import net.minecraft.util.registry.Registry;
@ -34,7 +30,10 @@ import java.nio.charset.StandardCharsets;
import java.nio.file.Files; import java.nio.file.Files;
import java.nio.file.Path; import java.nio.file.Path;
import java.nio.file.Paths; import java.nio.file.Paths;
import java.util.*; import java.util.HashSet;
import java.util.Locale;
import java.util.Optional;
import java.util.OptionalInt;
public class Extractor implements ModInitializer { public class Extractor implements ModInitializer {
public static final String MOD_ID = "valence_extractor"; public static final String MOD_ID = "valence_extractor";
@ -42,45 +41,85 @@ public class Extractor implements ModInitializer {
private Gson gson; private Gson gson;
private Path outputDirectory; private Path outputDirectory;
private static JsonElement trackedDataToJson(Object data) { private static TD2JResult trackedDataToJson(TrackedData<?> data, DataTracker tracker) {
if (data instanceof BlockPos bp) { final var handler = data.getType();
final var val = tracker.get(data);
if (handler == TrackedDataHandlerRegistry.BYTE) {
return new TD2JResult("byte", new JsonPrimitive((Byte) val));
} else if (handler == TrackedDataHandlerRegistry.INTEGER) {
return new TD2JResult("integer", new JsonPrimitive((Integer) val));
} else if (handler == TrackedDataHandlerRegistry.FLOAT) {
return new TD2JResult("float", new JsonPrimitive((Float) val));
} else if (handler == TrackedDataHandlerRegistry.STRING) {
return new TD2JResult("string", new JsonPrimitive((String) val));
} else if (handler == TrackedDataHandlerRegistry.TEXT_COMPONENT) {
// TODO: return text as json element.
return new TD2JResult("text_component", new JsonPrimitive(((Text) val).getString()));
} else if (handler == TrackedDataHandlerRegistry.OPTIONAL_TEXT_COMPONENT) {
var res = ((Optional<?>) val).map(o -> (JsonElement) new JsonPrimitive(((Text) o).getString())).orElse(JsonNull.INSTANCE);
return new TD2JResult("optional_text_component", res);
} else if (handler == TrackedDataHandlerRegistry.ITEM_STACK) {
// TODO
return new TD2JResult("item_stack", new JsonPrimitive(((ItemStack) val).toString()));
} else if (handler == TrackedDataHandlerRegistry.BOOLEAN) {
return new TD2JResult("boolean", new JsonPrimitive((Boolean) val));
} else if (handler == TrackedDataHandlerRegistry.ROTATION) {
var json = new JsonObject();
var ea = (EulerAngle) val;
json.addProperty("pitch", ea.getPitch());
json.addProperty("yaw", ea.getYaw());
json.addProperty("roll", ea.getRoll());
return new TD2JResult("rotation", json);
} else if (handler == TrackedDataHandlerRegistry.BLOCK_POS) {
var bp = (BlockPos) val;
var json = new JsonObject(); var json = new JsonObject();
json.addProperty("x", bp.getX()); json.addProperty("x", bp.getX());
json.addProperty("y", bp.getY()); json.addProperty("y", bp.getY());
json.addProperty("z", bp.getZ()); json.addProperty("z", bp.getZ());
return json; return new TD2JResult("block_pos", json);
} else if (data instanceof Boolean b) { } else if (handler == TrackedDataHandlerRegistry.OPTIONAL_BLOCK_POS) {
return new JsonPrimitive(b); return new TD2JResult("optional_block_pos", ((Optional<?>) val).map(o -> {
} else if (data instanceof Byte b) { var bp = (BlockPos) o;
return new JsonPrimitive(b); var json = new JsonObject();
} else if (data instanceof CatVariant cv) { json.addProperty("x", bp.getX());
return new JsonPrimitive(Registry.CAT_VARIANT.getId(cv).getPath()); json.addProperty("y", bp.getY());
} else if (data instanceof EntityPose ep) { json.addProperty("z", bp.getZ());
return new JsonPrimitive(ep.toString()); return (JsonElement) json;
} else if (data instanceof Direction d) { }).orElse(JsonNull.INSTANCE));
return new JsonPrimitive(d.toString()); } else if (handler == TrackedDataHandlerRegistry.FACING) {
} else if (data instanceof Float f) { return new TD2JResult("facing", new JsonPrimitive(val.toString()));
return new JsonPrimitive(f); } else if (handler == TrackedDataHandlerRegistry.OPTIONAL_UUID) {
} else if (data instanceof FrogVariant fv) { var res = ((Optional<?>) val).map(o -> (JsonElement) new JsonPrimitive(o.toString())).orElse(JsonNull.INSTANCE);
return new JsonPrimitive(Registry.FROG_VARIANT.getId(fv).getPath()); return new TD2JResult("optional_uuid", res);
} else if (data instanceof Integer i) { } else if (handler == TrackedDataHandlerRegistry.OPTIONAL_BLOCK_STATE) {
return new JsonPrimitive(i); // TODO: get raw block state ID.
} else if (data instanceof ItemStack is) { var res = ((Optional<?>) val).map(o -> (JsonElement) new JsonPrimitive(o.toString())).orElse(JsonNull.INSTANCE);
// TODO return new TD2JResult("optional_block_state", res);
return new JsonPrimitive(is.toString()); } else if (handler == TrackedDataHandlerRegistry.NBT_COMPOUND) {
} else if (data instanceof NbtCompound nbt) {
// TODO: base64 binary representation or SNBT? // TODO: base64 binary representation or SNBT?
return new JsonPrimitive(nbt.toString()); return new TD2JResult("nbt_compound", new JsonPrimitive(val.toString()));
} else if (data instanceof Optional<?> opt) { } else if (handler == TrackedDataHandlerRegistry.PARTICLE) {
var inner = opt.orElse(null); return new TD2JResult("particle", new JsonPrimitive(((ParticleEffect) val).asString()));
if (inner == null) { } else if (handler == TrackedDataHandlerRegistry.VILLAGER_DATA) {
return null; var vd = (VillagerData) val;
} else if (inner instanceof BlockPos) { var json = new JsonObject();
return Extractor.trackedDataToJson(inner); json.addProperty("type", vd.getType().toString());
} else if (inner instanceof BlockState bs) { json.addProperty("profession", vd.getProfession().toString());
// TODO: get raw block state ID. json.addProperty("level", vd.getLevel());
return new JsonPrimitive(bs.toString()); return new TD2JResult("villager_data", json);
} else if (inner instanceof GlobalPos gp) { } else if (handler == TrackedDataHandlerRegistry.OPTIONAL_INT) {
var opt = (OptionalInt) val;
return new TD2JResult("optional_int", opt.isPresent() ? new JsonPrimitive(opt.getAsInt()) : JsonNull.INSTANCE);
} else if (handler == TrackedDataHandlerRegistry.ENTITY_POSE) {
return new TD2JResult("entity_pose", new JsonPrimitive(val.toString()));
} else if (handler == TrackedDataHandlerRegistry.CAT_VARIANT) {
return new TD2JResult("cat_variant", new JsonPrimitive(Registry.CAT_VARIANT.getId((CatVariant) val).getPath()));
} else if (handler == TrackedDataHandlerRegistry.FROG_VARIANT) {
return new TD2JResult("frog_variant", new JsonPrimitive(Registry.FROG_VARIANT.getId((FrogVariant) val).getPath()));
} else if (handler == TrackedDataHandlerRegistry.OPTIONAL_GLOBAL_POS) {
return new TD2JResult("optional_global_pos", ((Optional<?>) val).map(o -> {
var gp = (GlobalPos) o;
var json = new JsonObject(); var json = new JsonObject();
json.addProperty("dimension", gp.getDimension().getValue().toString()); json.addProperty("dimension", gp.getDimension().getValue().toString());
@ -90,40 +129,14 @@ public class Extractor implements ModInitializer {
posJson.addProperty("z", gp.getPos().getZ()); posJson.addProperty("z", gp.getPos().getZ());
json.add("position", posJson); json.add("position", posJson);
return json; return (JsonElement) json;
} else if (inner instanceof Text) { }).orElse(JsonNull.INSTANCE));
return Extractor.trackedDataToJson(inner); } else if (handler == TrackedDataHandlerRegistry.PAINTING_VARIANT) {
} else if (inner instanceof UUID uuid) { var variant = ((RegistryEntry<?>) val).getKey().map(k -> k.getValue().getPath()).orElse("");
return new JsonPrimitive(uuid.toString()); return new TD2JResult("painting_variant", new JsonPrimitive(variant));
} else { } else {
throw new IllegalArgumentException("Unknown tracked optional type " + inner.getClass().getName()); throw new IllegalArgumentException("Unexpected tracked data type " + handler);
}
} else if (data instanceof OptionalInt oi) {
return oi.isPresent() ? new JsonPrimitive(oi.getAsInt()) : null;
} else if (data instanceof RegistryEntry<?> re) {
return new JsonPrimitive(re.getKey().map(k -> k.getValue().getPath()).orElse(""));
} else if (data instanceof ParticleEffect pe) {
return new JsonPrimitive(pe.asString());
} else if (data instanceof EulerAngle ea) {
var json = new JsonObject();
json.addProperty("yaw", ea.getYaw());
json.addProperty("pitch", ea.getPitch());
json.addProperty("roll", ea.getRoll());
return json;
} else if (data instanceof String s) {
return new JsonPrimitive(s);
} else if (data instanceof Text t) {
// TODO: return text as json element.
return new JsonPrimitive(t.getString());
} else if (data instanceof VillagerData vd) {
var json = new JsonObject();
json.addProperty("level", vd.getLevel());
json.addProperty("type", vd.getType().toString());
json.addProperty("profession", vd.getProfession().toString());
return json;
} }
throw new IllegalArgumentException("Unexpected tracked type " + data.getClass().getName());
} }
@Override @Override
@ -243,10 +256,11 @@ public class Extractor implements ModInitializer {
var fieldJson = new JsonObject(); var fieldJson = new JsonObject();
fieldJson.addProperty("name", entityField.getName().toLowerCase(Locale.ROOT)); fieldJson.addProperty("name", entityField.getName().toLowerCase(Locale.ROOT));
fieldJson.addProperty("index", data.getId()); fieldJson.addProperty("index", data.getId());
fieldJson.addProperty("type_id", TrackedDataHandlerRegistry.getId(data.getType()));
var dataTracker = (DataTracker) dataTrackerField.get(entityInstance); var dataTracker = (DataTracker) dataTrackerField.get(entityInstance);
fieldJson.add("default_value", Extractor.trackedDataToJson(dataTracker.get(data))); var res = Extractor.trackedDataToJson(data, dataTracker);
fieldJson.addProperty("type", res.type_name);
fieldJson.add("default_value", res.data);
fieldsJson.add(fieldJson); fieldsJson.add(fieldJson);
} }
@ -295,4 +309,7 @@ public class Extractor implements ModInitializer {
fileWriter.close(); fileWriter.close();
LOGGER.info("Wrote " + out.toAbsolutePath()); LOGGER.info("Wrote " + out.toAbsolutePath());
} }
private record TD2JResult(String type_name, JsonElement data) {
}
} }