Improve YMLWrapper

This commit is contained in:
2025-10-25 22:03:32 +02:00
parent 87a4836fa1
commit e6dea72024
4 changed files with 26 additions and 59 deletions
@@ -25,6 +25,7 @@ import java.io.File;
import java.util.Collections;
import java.util.List;
import java.util.Map;
import java.util.Objects;
import java.util.function.Function;
import java.util.stream.Collectors;
@@ -55,13 +56,23 @@ public abstract class YMLWrapper<M, ST, W> {
public abstract String getDefaultGameName();
public abstract String getString(String path, String defaultValue);
public abstract <T> T get(String path, T defaultValue, Function<Object, T> mapper);
public abstract int getInt(String path, int defaultValue);
public String getString(String path, String defaultValue) {
return get(path, defaultValue, Objects::toString);
}
public abstract double getDouble(String path, double defaultValue);
public int getInt(String path, int defaultValue) {
return get(path, defaultValue, Integer.class::cast);
}
public abstract boolean getBoolean(String path, boolean defaultValue);
public double getDouble(String path, double defaultValue) {
return get(path, defaultValue, Double.class::cast);
}
public boolean getBoolean(String path, boolean defaultValue) {
return get(path, defaultValue, Boolean.class::cast);
}
public final ST getSchematicType(String path, String defaultValue) {
String schematicType = getString(path, defaultValue);
@@ -36,7 +36,6 @@ public class CheckSchemTypeManager {
static {
File folder = new File(SchematicSystem.getInstance().getDataFolder().getParentFile(), "FightSystem");
if(folder.exists()) {
for(File configFile : folder.listFiles((file, name) -> name.endsWith(".yml") && !name.endsWith(".kits.yml"))) {
GameModeConfig<Material, SchematicType, String> gameModeConfig = new GameModeConfig<>(YMLWrapperImpl.ofTyped(configFile));
@@ -101,27 +101,13 @@ public class YMLWrapperImpl<M, ST, W> extends YMLWrapper<M, ST, W> {
}
@Override
public String getString(String path, String defaultValue) {
public <T> T get(String path, T defaultValue, Function<Object, T> mapper) {
if (config == null) return defaultValue;
return config.getString(pathPrefix + path, defaultValue);
}
@Override
public int getInt(String path, int defaultValue) {
if (config == null) return defaultValue;
return config.getInt(pathPrefix + path, defaultValue);
}
@Override
public double getDouble(String path, double defaultValue) {
if (config == null) return defaultValue;
return config.getDouble(pathPrefix + path, defaultValue);
}
@Override
public boolean getBoolean(String path, boolean defaultValue) {
if (config == null) return defaultValue;
return config.getBoolean(pathPrefix + path, defaultValue);
try {
return mapper.apply(config.get(path, defaultValue));
} catch (ClassCastException e) {
return defaultValue;
}
}
@Override
@@ -88,41 +88,12 @@ public class YMLWrapperImpl<ST> extends YMLWrapper<String, ST, String> {
}
@Override
public String getString(String path, String defaultValue) {
public <T> T get(String path, T defaultValue, Function<Object, T> mapper) {
Object value = this.document.get(path);
if (value instanceof String) {
return (String) value;
} else {
return defaultValue;
}
}
@Override
public int getInt(String path, int defaultValue) {
Object value = this.document.get(path);
if (value instanceof Integer) {
return (Integer) value;
} else {
return defaultValue;
}
}
@Override
public double getDouble(String path, double defaultValue) {
Object value = this.document.get(path);
if (value instanceof Double) {
return (Double) value;
} else {
return defaultValue;
}
}
@Override
public boolean getBoolean(String path, boolean defaultValue) {
Object value = this.document.get(path);
if (value instanceof Boolean) {
return (Boolean) value;
} else {
if (value == null) return defaultValue;
try {
return mapper.apply(value);
} catch (ClassCastException e) {
return defaultValue;
}
}