mirror of
https://github.com/PolyhedralDev/Terra.git
synced 2026-06-17 14:21:08 +00:00
Use tectonic properly
This commit is contained in:
@@ -35,7 +35,6 @@ import com.dfsek.terra.config.loaders.LinkedHashMapLoader;
|
|||||||
import com.dfsek.terra.config.loaders.MaterialSetLoader;
|
import com.dfsek.terra.config.loaders.MaterialSetLoader;
|
||||||
import com.dfsek.terra.config.loaders.ProbabilityCollectionLoader;
|
import com.dfsek.terra.config.loaders.ProbabilityCollectionLoader;
|
||||||
import com.dfsek.terra.config.loaders.RangeLoader;
|
import com.dfsek.terra.config.loaders.RangeLoader;
|
||||||
import com.dfsek.terra.config.loaders.RangeLoader.RangeMap;
|
|
||||||
import com.dfsek.terra.config.loaders.VersionLoader;
|
import com.dfsek.terra.config.loaders.VersionLoader;
|
||||||
import com.dfsek.terra.config.loaders.VersionRangeLoader;
|
import com.dfsek.terra.config.loaders.VersionRangeLoader;
|
||||||
|
|
||||||
@@ -51,7 +50,6 @@ public class GenericLoaders implements LoaderRegistrar {
|
|||||||
public void register(TypeRegistry registry) {
|
public void register(TypeRegistry registry) {
|
||||||
registry.registerLoader(ProbabilityCollection.class, new ProbabilityCollectionLoader())
|
registry.registerLoader(ProbabilityCollection.class, new ProbabilityCollectionLoader())
|
||||||
.registerLoader(Range.class, new RangeLoader())
|
.registerLoader(Range.class, new RangeLoader())
|
||||||
.registerLoader(RangeMap.class, RangeLoader.RangeMapTemplate::new) // Needed to use ObjectTemplates in TypeLoaders
|
|
||||||
.registerLoader(Version.class, new VersionLoader())
|
.registerLoader(Version.class, new VersionLoader())
|
||||||
.registerLoader(MaterialSet.class, new MaterialSetLoader())
|
.registerLoader(MaterialSet.class, new MaterialSetLoader())
|
||||||
.registerLoader(VersionRange.class, new VersionRangeLoader())
|
.registerLoader(VersionRange.class, new VersionRangeLoader())
|
||||||
|
|||||||
+6
-7
@@ -24,13 +24,14 @@ import com.dfsek.tectonic.api.exception.LoadException;
|
|||||||
import com.dfsek.tectonic.api.loader.ConfigLoader;
|
import com.dfsek.tectonic.api.loader.ConfigLoader;
|
||||||
import com.dfsek.tectonic.api.loader.type.TypeLoader;
|
import com.dfsek.tectonic.api.loader.type.TypeLoader;
|
||||||
|
|
||||||
|
import com.dfsek.tectonic.impl.MapConfiguration;
|
||||||
|
|
||||||
import com.dfsek.terra.api.config.meta.Meta;
|
import com.dfsek.terra.api.config.meta.Meta;
|
||||||
|
|
||||||
import org.jetbrains.annotations.NotNull;
|
import org.jetbrains.annotations.NotNull;
|
||||||
|
|
||||||
import java.lang.reflect.AnnotatedType;
|
import java.lang.reflect.AnnotatedType;
|
||||||
import java.util.Map;
|
import java.util.Map;
|
||||||
import java.util.function.Supplier;
|
|
||||||
|
|
||||||
import com.dfsek.terra.api.util.ConstantRange;
|
import com.dfsek.terra.api.util.ConstantRange;
|
||||||
import com.dfsek.terra.api.util.Range;
|
import com.dfsek.terra.api.util.Range;
|
||||||
@@ -42,19 +43,17 @@ public class RangeLoader implements TypeLoader<Range> {
|
|||||||
public Range load(@NotNull AnnotatedType type, @NotNull Object o, @NotNull ConfigLoader configLoader, DepthTracker depthTracker)
|
public Range load(@NotNull AnnotatedType type, @NotNull Object o, @NotNull ConfigLoader configLoader, DepthTracker depthTracker)
|
||||||
throws LoadException {
|
throws LoadException {
|
||||||
if(o instanceof Map) {
|
if(o instanceof Map) {
|
||||||
return configLoader.loadType(RangeMap.class, o, depthTracker).get();
|
return configLoader.load(new RangeMapTemplate(), new MapConfiguration((Map<String, Object>) o), depthTracker).get();
|
||||||
} else {
|
} else {
|
||||||
int h = configLoader.loadType(Integer.class, o, depthTracker);
|
int h = configLoader.loadType(Integer.class, o, depthTracker);
|
||||||
return new ConstantRange(h, h + 1);
|
return new ConstantRange(h, h + 1);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
public interface RangeMap extends Supplier<Range> {}
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Template needed so keys can be meta annotated, otherwise the loader could just grab keys directly from the object
|
* Template needed so keys can be meta annotated, otherwise the loader could just grab keys directly from the object
|
||||||
*/
|
*/
|
||||||
public static class RangeMapTemplate implements ObjectTemplate<RangeMap> {
|
public static class RangeMapTemplate implements ObjectTemplate<Range> {
|
||||||
@Value("min")
|
@Value("min")
|
||||||
private @Meta int min;
|
private @Meta int min;
|
||||||
|
|
||||||
@@ -62,8 +61,8 @@ public class RangeLoader implements TypeLoader<Range> {
|
|||||||
private @Meta int max;
|
private @Meta int max;
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public RangeMap get() {
|
public Range get() {
|
||||||
return () -> new ConstantRange(min, max);
|
return new ConstantRange(min, max);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
Reference in New Issue
Block a user