From 18ccb75cf31b86c30a1fe47b75cdf18147744b53 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Florian=20N=C3=BCcke?= Date: Fri, 22 Sep 2023 10:17:07 +0200 Subject: [PATCH] Fix parsing float config values. Fixes #137. Fixes #138. --- .../java/li/cil/scannable/util/ConfigManager.java | 11 ++++++----- 1 file changed, 6 insertions(+), 5 deletions(-) diff --git a/common/src/main/java/li/cil/scannable/util/ConfigManager.java b/common/src/main/java/li/cil/scannable/util/ConfigManager.java index 449a62e..c8e2125 100644 --- a/common/src/main/java/li/cil/scannable/util/ConfigManager.java +++ b/common/src/main/java/li/cil/scannable/util/ConfigManager.java @@ -222,14 +222,15 @@ private static ConfigFieldPair parseLongField(final Object instance, final Fi } private static ConfigFieldPair parseFloatField(final Object instance, final Field field, final Builder builder) throws IllegalAccessException { - final float defaultValue = field.getFloat(instance); - final float minValue = (float) getMin(field); - final float maxValue = (float) getMax(field); + // Forge config does not natively support floats, so we map float fields to double config values. + final double defaultValue = field.getFloat(instance); + final double minValue = getMin(field); + final double maxValue = getMax(field); final var configValue = withCommonAttributes(field, builder) - .defineInRange(getPath(field), defaultValue, minValue, maxValue, Float.class); + .defineInRange(getPath(field), defaultValue, minValue, maxValue, Double.class); - return new SetFieldConfigItem<>(field, configValue); + return new SetFieldConfigItem<>(field, configValue, value -> (float) (double) value); } private static ConfigFieldPair parseDoubleField(final Object instance, final Field field, final Builder builder) throws IllegalAccessException {