mirror of
https://github.com/Multiverse/Multiverse-Core.git
synced 2025-01-25 01:31:24 +01:00
Move property handling to a separate class
This commit is contained in:
parent
6fe87fbc7b
commit
4084cd4af1
@ -17,6 +17,7 @@ import org.jvnet.hk2.annotations.Service;
|
|||||||
import org.mvplugins.multiverse.core.MultiverseCore;
|
import org.mvplugins.multiverse.core.MultiverseCore;
|
||||||
import org.mvplugins.multiverse.core.api.MVConfig;
|
import org.mvplugins.multiverse.core.api.MVConfig;
|
||||||
import org.mvplugins.multiverse.core.configuration.handle.CommentedYamlConfigHandle;
|
import org.mvplugins.multiverse.core.configuration.handle.CommentedYamlConfigHandle;
|
||||||
|
import org.mvplugins.multiverse.core.configuration.handle.StringPropertyHandle;
|
||||||
import org.mvplugins.multiverse.core.configuration.migration.BooleanMigratorAction;
|
import org.mvplugins.multiverse.core.configuration.migration.BooleanMigratorAction;
|
||||||
import org.mvplugins.multiverse.core.configuration.migration.ConfigMigrator;
|
import org.mvplugins.multiverse.core.configuration.migration.ConfigMigrator;
|
||||||
import org.mvplugins.multiverse.core.configuration.migration.IntegerMigratorAction;
|
import org.mvplugins.multiverse.core.configuration.migration.IntegerMigratorAction;
|
||||||
@ -33,6 +34,7 @@ public class MVCoreConfig implements MVConfig {
|
|||||||
private final Path configPath;
|
private final Path configPath;
|
||||||
private final MVCoreConfigNodes configNodes;
|
private final MVCoreConfigNodes configNodes;
|
||||||
private final CommentedYamlConfigHandle configHandle;
|
private final CommentedYamlConfigHandle configHandle;
|
||||||
|
private final StringPropertyHandle stringPropertyHandle;
|
||||||
|
|
||||||
@Inject
|
@Inject
|
||||||
MVCoreConfig(@NotNull MultiverseCore core, @NotNull PluginManager pluginManager) {
|
MVCoreConfig(@NotNull MultiverseCore core, @NotNull PluginManager pluginManager) {
|
||||||
@ -71,7 +73,7 @@ public class MVCoreConfig implements MVConfig {
|
|||||||
.build())
|
.build())
|
||||||
.build())
|
.build())
|
||||||
.build();
|
.build();
|
||||||
|
this.stringPropertyHandle = new StringPropertyHandle(configHandle);
|
||||||
load();
|
load();
|
||||||
save();
|
save();
|
||||||
}
|
}
|
||||||
@ -115,22 +117,22 @@ public class MVCoreConfig implements MVConfig {
|
|||||||
|
|
||||||
@Override
|
@Override
|
||||||
public Collection<String> suggestPropertyValues(String name, String input) {
|
public Collection<String> suggestPropertyValues(String name, String input) {
|
||||||
return configHandle.suggestPropertyValues(name, input);
|
return stringPropertyHandle.getPropertySuggestedValues(name, input);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public Try<Object> getProperty(String name) {
|
public Try<Object> getProperty(String name) {
|
||||||
return configHandle.getProperty(name);
|
return stringPropertyHandle.getProperty(name);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public Try<Void> setProperty(String name, Object value) {
|
public Try<Void> setProperty(String name, Object value) {
|
||||||
return configHandle.setProperty(name, value);
|
return stringPropertyHandle.setProperty(name, value);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public Try<Void> setPropertyString(String name, String value) {
|
public Try<Void> setPropertyString(String name, String value) {
|
||||||
return configHandle.setPropertyString(name, value);
|
return stringPropertyHandle.setPropertyString(name, value);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
@ -1,7 +1,5 @@
|
|||||||
package org.mvplugins.multiverse.core.configuration.handle;
|
package org.mvplugins.multiverse.core.configuration.handle;
|
||||||
|
|
||||||
import java.util.Collection;
|
|
||||||
import java.util.Collections;
|
|
||||||
import java.util.logging.Logger;
|
import java.util.logging.Logger;
|
||||||
|
|
||||||
import io.vavr.control.Try;
|
import io.vavr.control.Try;
|
||||||
@ -11,8 +9,6 @@ import org.jetbrains.annotations.NotNull;
|
|||||||
import org.jetbrains.annotations.Nullable;
|
import org.jetbrains.annotations.Nullable;
|
||||||
|
|
||||||
import org.mvplugins.multiverse.core.configuration.migration.ConfigMigrator;
|
import org.mvplugins.multiverse.core.configuration.migration.ConfigMigrator;
|
||||||
import org.mvplugins.multiverse.core.configuration.node.ConfigNodeNotFoundException;
|
|
||||||
import org.mvplugins.multiverse.core.configuration.node.Node;
|
|
||||||
import org.mvplugins.multiverse.core.configuration.node.NodeGroup;
|
import org.mvplugins.multiverse.core.configuration.node.NodeGroup;
|
||||||
import org.mvplugins.multiverse.core.configuration.node.ValueNode;
|
import org.mvplugins.multiverse.core.configuration.node.ValueNode;
|
||||||
|
|
||||||
@ -21,12 +17,12 @@ import org.mvplugins.multiverse.core.configuration.node.ValueNode;
|
|||||||
*/
|
*/
|
||||||
public abstract class GenericConfigHandle<C extends ConfigurationSection> {
|
public abstract class GenericConfigHandle<C extends ConfigurationSection> {
|
||||||
protected final @Nullable Logger logger;
|
protected final @Nullable Logger logger;
|
||||||
protected final @Nullable NodeGroup nodes;
|
protected final @NotNull NodeGroup nodes;
|
||||||
protected final @Nullable ConfigMigrator migrator;
|
protected final @Nullable ConfigMigrator migrator;
|
||||||
|
|
||||||
protected C config;
|
protected C config;
|
||||||
|
|
||||||
protected GenericConfigHandle(@Nullable Logger logger, @Nullable NodeGroup nodes, @Nullable ConfigMigrator migrator) {
|
protected GenericConfigHandle(@Nullable Logger logger, @NotNull NodeGroup nodes, @Nullable ConfigMigrator migrator) {
|
||||||
this.logger = logger;
|
this.logger = logger;
|
||||||
this.nodes = nodes;
|
this.nodes = nodes;
|
||||||
this.migrator = migrator;
|
this.migrator = migrator;
|
||||||
@ -70,58 +66,6 @@ public abstract class GenericConfigHandle<C extends ConfigurationSection> {
|
|||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
|
||||||
* Auto-complete suggestions for a property.
|
|
||||||
*
|
|
||||||
* @param name The name of the node.
|
|
||||||
* @param input The current user input.
|
|
||||||
* @return A collection of possible string values.
|
|
||||||
*/
|
|
||||||
public Collection<String> suggestPropertyValues(@Nullable String name, @Nullable String input) {
|
|
||||||
return findNode(name, ValueNode.class)
|
|
||||||
.map(node -> node.suggest(input))
|
|
||||||
.getOrElse(Collections.emptyList());
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Gets the value of a node, if the node has a default value, it will be returned if the node is not found.
|
|
||||||
*
|
|
||||||
* @param name The name of the node.
|
|
||||||
* @return The value of the node, or an error if the node was not found.
|
|
||||||
*/
|
|
||||||
public Try<Object> getProperty(@Nullable String name) {
|
|
||||||
return findNode(name, ValueNode.class).map(this::get);
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Sets the string value of a node, if the validator is not null, it will be tested first.
|
|
||||||
*
|
|
||||||
* @param name The name of the node.
|
|
||||||
* @param value The string value to set.
|
|
||||||
* @return Empty try if the value was set, try containing an error otherwise.
|
|
||||||
*/
|
|
||||||
public Try<Void> setPropertyString(@Nullable String name, @Nullable String value) {
|
|
||||||
return findNode(name, ValueNode.class)
|
|
||||||
.flatMap(node -> node.parseFromString(value)
|
|
||||||
.flatMap(parsedValue -> set(node, parsedValue)));
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Sets the value of a node, if the validator is not null, it will be tested first.
|
|
||||||
*
|
|
||||||
* @param name The name of the node.
|
|
||||||
* @param value The value to set.
|
|
||||||
* @return Empty try if the value was set, try containing an error otherwise.
|
|
||||||
*/
|
|
||||||
public Try<Void> setProperty(@Nullable String name, @Nullable Object value) {
|
|
||||||
return findNode(name, ValueNode.class).flatMap(node -> set(node, value));
|
|
||||||
}
|
|
||||||
|
|
||||||
private <T extends Node> Try<T> findNode(@Nullable String name, @NotNull Class<T> type) {
|
|
||||||
return nodes.findNode(name, type)
|
|
||||||
.toTry(() -> new ConfigNodeNotFoundException(name));
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Gets the value of a node, if the node has a default value, it will be returned if the node is not found.
|
* Gets the value of a node, if the node has a default value, it will be returned if the node is not found.
|
||||||
*
|
*
|
||||||
@ -157,6 +101,15 @@ public abstract class GenericConfigHandle<C extends ConfigurationSection> {
|
|||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Gets the configuration. Mainly used for {@link StringPropertyHandle}.
|
||||||
|
*
|
||||||
|
* @return The configuration.
|
||||||
|
*/
|
||||||
|
@NotNull NodeGroup getNodes() {
|
||||||
|
return nodes;
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Sets the default value of a node.
|
* Sets the default value of a node.
|
||||||
*
|
*
|
||||||
|
@ -0,0 +1,99 @@
|
|||||||
|
package org.mvplugins.multiverse.core.configuration.handle;
|
||||||
|
|
||||||
|
import java.util.Collection;
|
||||||
|
import java.util.Collections;
|
||||||
|
|
||||||
|
import io.vavr.control.Try;
|
||||||
|
import org.jetbrains.annotations.NotNull;
|
||||||
|
import org.jetbrains.annotations.Nullable;
|
||||||
|
|
||||||
|
import org.mvplugins.multiverse.core.configuration.node.ConfigNodeNotFoundException;
|
||||||
|
import org.mvplugins.multiverse.core.configuration.node.Node;
|
||||||
|
import org.mvplugins.multiverse.core.configuration.node.ValueNode;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Handles setting of config with string names and values.
|
||||||
|
*/
|
||||||
|
public class StringPropertyHandle {
|
||||||
|
private final @NotNull GenericConfigHandle<?> handle;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Creates a new string property handle.
|
||||||
|
*
|
||||||
|
* @param handle The handle to wrap.
|
||||||
|
*/
|
||||||
|
public StringPropertyHandle(@NotNull GenericConfigHandle<?> handle) {
|
||||||
|
this.handle = handle;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Gets the names of all properties in this handle.
|
||||||
|
*
|
||||||
|
* @return The names of all properties in this handle.
|
||||||
|
*/
|
||||||
|
public Collection<String> getPropertyNames() {
|
||||||
|
return handle.getNodes().getNames();
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Gets the type of a property.
|
||||||
|
*
|
||||||
|
* @param name The name of the property.
|
||||||
|
* @return The type of the property, or an error if the property was not found.
|
||||||
|
*/
|
||||||
|
public Try<Class<?>> getPropertyType(@Nullable String name) {
|
||||||
|
return findNode(name, ValueNode.class).map(ValueNode::getType);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Auto-complete suggestions for a property.
|
||||||
|
*
|
||||||
|
* @param name The name of the node.
|
||||||
|
* @param input The current user input.
|
||||||
|
* @return A collection of possible string values.
|
||||||
|
*/
|
||||||
|
public Collection<String> getPropertySuggestedValues(@Nullable String name, @Nullable String input) {
|
||||||
|
return findNode(name, ValueNode.class)
|
||||||
|
.map(node -> node.suggest(input))
|
||||||
|
.getOrElse(Collections.emptyList());
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Gets the value of a node, if the node has a default value, it will be returned if the node is not found.
|
||||||
|
*
|
||||||
|
* @param name The name of the node.
|
||||||
|
* @return The value of the node, or an error if the node was not found.
|
||||||
|
*/
|
||||||
|
public Try<Object> getProperty(@Nullable String name) {
|
||||||
|
return findNode(name, ValueNode.class).map(node -> handle.get(node));
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Sets the value of a node, if the validator is not null, it will be tested first.
|
||||||
|
*
|
||||||
|
* @param name The name of the node.
|
||||||
|
* @param value The value to set.
|
||||||
|
* @return Empty try if the value was set, try containing an error otherwise.
|
||||||
|
*/
|
||||||
|
public Try<Void> setProperty(@Nullable String name, @Nullable Object value) {
|
||||||
|
return findNode(name, ValueNode.class).flatMap(node -> handle.set(node, value));
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Sets the string value of a node, if the validator is not null, it will be tested first.
|
||||||
|
*
|
||||||
|
* @param name The name of the node.
|
||||||
|
* @param value The string value to set.
|
||||||
|
* @return Empty try if the value was set, try containing an error otherwise.
|
||||||
|
*/
|
||||||
|
public Try<Void> setPropertyString(@Nullable String name, @Nullable String value) {
|
||||||
|
return findNode(name, ValueNode.class)
|
||||||
|
.flatMap(node -> node.parseFromString(value)
|
||||||
|
.flatMap(parsedValue -> handle.set(node, parsedValue)));
|
||||||
|
}
|
||||||
|
|
||||||
|
private <T extends Node> Try<T> findNode(@Nullable String name, @NotNull Class<T> type) {
|
||||||
|
return handle.getNodes().findNode(name, type)
|
||||||
|
.toTry(() -> new ConfigNodeNotFoundException(name));
|
||||||
|
}
|
||||||
|
}
|
@ -16,6 +16,7 @@ import org.jetbrains.annotations.Nullable;
|
|||||||
|
|
||||||
import org.mvplugins.multiverse.core.MultiverseCore;
|
import org.mvplugins.multiverse.core.MultiverseCore;
|
||||||
import org.mvplugins.multiverse.core.configuration.handle.ConfigurationSectionHandle;
|
import org.mvplugins.multiverse.core.configuration.handle.ConfigurationSectionHandle;
|
||||||
|
import org.mvplugins.multiverse.core.configuration.handle.StringPropertyHandle;
|
||||||
import org.mvplugins.multiverse.core.configuration.migration.BooleanMigratorAction;
|
import org.mvplugins.multiverse.core.configuration.migration.BooleanMigratorAction;
|
||||||
import org.mvplugins.multiverse.core.configuration.migration.ConfigMigrator;
|
import org.mvplugins.multiverse.core.configuration.migration.ConfigMigrator;
|
||||||
import org.mvplugins.multiverse.core.configuration.migration.IntegerMigratorAction;
|
import org.mvplugins.multiverse.core.configuration.migration.IntegerMigratorAction;
|
||||||
@ -33,6 +34,7 @@ public final class WorldConfig {
|
|||||||
private final String worldName;
|
private final String worldName;
|
||||||
private final WorldConfigNodes configNodes;
|
private final WorldConfigNodes configNodes;
|
||||||
private final ConfigurationSectionHandle configHandle;
|
private final ConfigurationSectionHandle configHandle;
|
||||||
|
private final StringPropertyHandle stringPropertyHandle;
|
||||||
|
|
||||||
WorldConfig(
|
WorldConfig(
|
||||||
@NotNull String worldName,
|
@NotNull String worldName,
|
||||||
@ -47,6 +49,7 @@ public final class WorldConfig {
|
|||||||
.addVersionMigrator(initialVersionMigrator())
|
.addVersionMigrator(initialVersionMigrator())
|
||||||
.build())
|
.build())
|
||||||
.build();
|
.build();
|
||||||
|
this.stringPropertyHandle = new StringPropertyHandle(configHandle);
|
||||||
load();
|
load();
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -119,11 +122,11 @@ public final class WorldConfig {
|
|||||||
}
|
}
|
||||||
|
|
||||||
public Try<Object> getProperty(String name) {
|
public Try<Object> getProperty(String name) {
|
||||||
return configHandle.getProperty(name);
|
return stringPropertyHandle.getProperty(name);
|
||||||
}
|
}
|
||||||
|
|
||||||
public Try<Void> setProperty(String name, Object value) {
|
public Try<Void> setProperty(String name, Object value) {
|
||||||
return configHandle.setProperty(name, value);
|
return stringPropertyHandle.setProperty(name, value);
|
||||||
}
|
}
|
||||||
|
|
||||||
public boolean getAdjustSpawn() {
|
public boolean getAdjustSpawn() {
|
||||||
|
Loading…
Reference in New Issue
Block a user