WIP: configuration
This commit is contained in:
parent
92d4ccab6c
commit
9f2b1b50c4
8 changed files with 276 additions and 225 deletions
|
@ -1,5 +1,10 @@
|
|||
package ru.betterend.config;
|
||||
|
||||
import org.jetbrains.annotations.Nullable;
|
||||
|
||||
import com.google.gson.JsonObject;
|
||||
|
||||
import net.minecraft.util.JsonHelper;
|
||||
import ru.betterend.BetterEnd;
|
||||
import ru.betterend.config.ConfigKeeper.BooleanEntry;
|
||||
import ru.betterend.config.ConfigKeeper.Entry;
|
||||
|
@ -11,28 +16,50 @@ import ru.betterend.config.ConfigKeeper.StringEntry;
|
|||
public abstract class Config {
|
||||
|
||||
protected final ConfigKeeper configKeeper = new ConfigKeeper();
|
||||
protected JsonObject settings;
|
||||
|
||||
public abstract void saveChanges();
|
||||
protected abstract void registerEntries();
|
||||
|
||||
public <E extends Entry<?>> E getEntry(String key) {
|
||||
return this.configKeeper.getEntry(key);
|
||||
@Nullable
|
||||
public <E extends Entry<?>> E getEntry(String category, String key) {
|
||||
return this.configKeeper.getEntry(category, key);
|
||||
}
|
||||
|
||||
public <T> T getDefault(String key) {
|
||||
Entry<T> entry = configKeeper.getEntry(key);
|
||||
@Nullable
|
||||
public <T> T getDefault(String category, String key) {
|
||||
Entry<T> entry = configKeeper.getEntry(category, key);
|
||||
return entry != null ? entry.getDefault() : null;
|
||||
}
|
||||
|
||||
public String getString(String key) {
|
||||
String str = configKeeper.getValue(key);
|
||||
return str != null ? str : "";
|
||||
public String getString(String category, String key, String defaultValue) {
|
||||
String str = configKeeper.getValue(category, key);
|
||||
if (str == null) {
|
||||
StringEntry entry = this.configKeeper.registerEntry(category, key, new StringEntry(defaultValue));
|
||||
if (settings != null && settings.has(category)) {
|
||||
JsonObject params = JsonHelper.getObject(settings, category);
|
||||
key += " [default: " + defaultValue + "]";
|
||||
if (params.has(key)) {
|
||||
entry.fromString(JsonHelper.getString(params, key));
|
||||
return entry.getValue();
|
||||
}
|
||||
}
|
||||
}
|
||||
return str != null ? str : defaultValue;
|
||||
}
|
||||
|
||||
public boolean setString(String key, String value) {
|
||||
@Nullable
|
||||
public String getString(String category, String key) {
|
||||
String str = configKeeper.getValue(category, key);
|
||||
return str != null ? str : null;
|
||||
}
|
||||
|
||||
public boolean setString(String category, String key, String value) {
|
||||
try {
|
||||
StringEntry entry = configKeeper.getEntry(key);
|
||||
StringEntry entry = configKeeper.getEntry(category, key);
|
||||
if (entry == null) return false;
|
||||
entry.setValue(value);
|
||||
this.configKeeper.set(key, entry);
|
||||
this.configKeeper.set(category, key, entry);
|
||||
|
||||
return true;
|
||||
} catch (NullPointerException ex) {
|
||||
|
@ -42,16 +69,33 @@ public abstract class Config {
|
|||
return false;
|
||||
}
|
||||
|
||||
public int getInt(String key) {
|
||||
Integer val = configKeeper.getValue(key);
|
||||
public int getInt(String category, String key, int defaultValue) {
|
||||
Integer val = configKeeper.getValue(category, key);
|
||||
if (val == null) {
|
||||
IntegerEntry entry = this.configKeeper.registerEntry(category, key, new IntegerEntry(defaultValue));
|
||||
if (settings != null && settings.has(category)) {
|
||||
JsonObject params = JsonHelper.getObject(settings, category);
|
||||
key += " [default: " + defaultValue + "]";
|
||||
if (params.has(key)) {
|
||||
entry.fromString(JsonHelper.getString(params, key));
|
||||
return entry.getValue();
|
||||
}
|
||||
}
|
||||
}
|
||||
return val != null ? val : defaultValue;
|
||||
}
|
||||
|
||||
public int getInt(String category, String key) {
|
||||
Integer val = configKeeper.getValue(category, key);
|
||||
return val != null ? val : 0;
|
||||
}
|
||||
|
||||
public boolean setInt(String key, int value) {
|
||||
public boolean setInt(String category, String key, int value) {
|
||||
try {
|
||||
IntegerEntry entry = configKeeper.getEntry(key);
|
||||
IntegerEntry entry = configKeeper.getEntry(category, key);
|
||||
if (entry == null) return false;
|
||||
entry.setValue(value);
|
||||
this.configKeeper.set(key, entry);
|
||||
this.configKeeper.set(category, key, entry);
|
||||
|
||||
return true;
|
||||
} catch (NullPointerException ex) {
|
||||
|
@ -61,11 +105,12 @@ public abstract class Config {
|
|||
return false;
|
||||
}
|
||||
|
||||
public <T extends Comparable<T>> boolean setRanged(String key, T value) {
|
||||
public <T extends Comparable<T>> boolean setRanged(String category, String key, T value) {
|
||||
try {
|
||||
RangeEntry<T> entry = configKeeper.getEntry(key);
|
||||
RangeEntry<T> entry = configKeeper.getEntry(category, key);
|
||||
if (entry == null) return false;
|
||||
entry.setValue(value);
|
||||
this.configKeeper.set(key, entry);
|
||||
this.configKeeper.set(category, key, entry);
|
||||
|
||||
return true;
|
||||
} catch (NullPointerException | ClassCastException ex) {
|
||||
|
@ -75,16 +120,33 @@ public abstract class Config {
|
|||
return false;
|
||||
}
|
||||
|
||||
public float getFloat(String key) {
|
||||
Float val = configKeeper.getValue(key);
|
||||
public float getFloat(String category, String key, float defaultValue) {
|
||||
Float val = configKeeper.getValue(category, key);
|
||||
if (val == null) {
|
||||
FloatEntry entry = this.configKeeper.registerEntry(category, key, new FloatEntry(defaultValue));
|
||||
if (settings != null && settings.has(category)) {
|
||||
JsonObject params = JsonHelper.getObject(settings, category);
|
||||
key += " [default: " + defaultValue + "]";
|
||||
if (params.has(key)) {
|
||||
entry.fromString(JsonHelper.getString(params, key));
|
||||
return entry.getValue();
|
||||
}
|
||||
}
|
||||
}
|
||||
return val != null ? val : defaultValue;
|
||||
}
|
||||
|
||||
public float getFloat(String category, String key) {
|
||||
Float val = configKeeper.getValue(category, key);
|
||||
return val != null ? val : 0.0F;
|
||||
}
|
||||
|
||||
public boolean setFloat(String key, float value) {
|
||||
public boolean setFloat(String category, String key, float value) {
|
||||
try {
|
||||
FloatEntry entry = configKeeper.getEntry(key);
|
||||
FloatEntry entry = configKeeper.getEntry(category, key);
|
||||
if (entry == null) return false;
|
||||
entry.setValue(value);
|
||||
this.configKeeper.set(key, entry);
|
||||
this.configKeeper.set(category, key, entry);
|
||||
|
||||
return true;
|
||||
} catch (NullPointerException ex) {
|
||||
|
@ -94,16 +156,33 @@ public abstract class Config {
|
|||
return false;
|
||||
}
|
||||
|
||||
public boolean getBoolean(String key) {
|
||||
Boolean val = configKeeper.getValue(key);
|
||||
public boolean getBoolean(String category, String key, boolean defaultValue) {
|
||||
Boolean val = configKeeper.getValue(category, key);
|
||||
if (val == null) {
|
||||
BooleanEntry entry = this.configKeeper.registerEntry(category, key, new BooleanEntry(defaultValue));
|
||||
if (settings != null && settings.has(category)) {
|
||||
JsonObject params = JsonHelper.getObject(settings, category);
|
||||
key += " [default: " + defaultValue + "]";
|
||||
if (params.has(key)) {
|
||||
entry.fromString(JsonHelper.getString(params, key));
|
||||
return entry.getValue();
|
||||
}
|
||||
}
|
||||
}
|
||||
return val != null ? val : defaultValue;
|
||||
}
|
||||
|
||||
public boolean getBoolean(String category, String key) {
|
||||
Boolean val = configKeeper.getValue(category, key);
|
||||
return val != null ? val : false;
|
||||
}
|
||||
|
||||
public boolean setBoolean(String key, boolean value) {
|
||||
public boolean setBoolean(String category, String key, boolean value) {
|
||||
try {
|
||||
BooleanEntry entry = configKeeper.getEntry(key);
|
||||
BooleanEntry entry = configKeeper.getEntry(category, key);
|
||||
if (entry == null) return false;
|
||||
entry.setValue(value);
|
||||
this.configKeeper.set(key, entry);
|
||||
this.configKeeper.set(category, key, entry);
|
||||
|
||||
return true;
|
||||
} catch (NullPointerException ex) {
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue