child.yml was a mistake

This commit is contained in:
nossr50 2019-02-18 09:04:20 -08:00
parent d7e0c95984
commit f08456b789
6 changed files with 56 additions and 195 deletions

View File

@ -1,59 +0,0 @@
package com.gmail.nossr50.config;
import com.gmail.nossr50.datatypes.skills.PrimarySkillType;
import com.gmail.nossr50.skills.child.FamilyTree;
import com.gmail.nossr50.util.StringUtils;
import org.bukkit.configuration.file.YamlConfiguration;
import java.util.EnumSet;
public class ChildConfig extends ConfigCollection {
public ChildConfig() {
super("child.yml");
}
@Override
protected void register() {
config.setDefaults(YamlConfiguration.loadConfiguration(plugin.getResourceAsReader("child.yml")));
FamilyTree.clearRegistrations(); // when reloading, need to clear statics
for (PrimarySkillType skill : PrimarySkillType.CHILD_SKILLS) {
plugin.debug("Finding parents of " + skill.name());
EnumSet<PrimarySkillType> parentSkills = EnumSet.noneOf(PrimarySkillType.class);
boolean useDefaults = false; // If we had an error we back out and use defaults
for (String name : config.getStringList(StringUtils.getCapitalized(skill.name()))) {
try {
PrimarySkillType parentSkill = PrimarySkillType.valueOf(name.toUpperCase());
FamilyTree.enforceNotChildSkill(parentSkill);
parentSkills.add(parentSkill);
} catch (IllegalArgumentException ex) {
plugin.getLogger().warning(name + " is not a valid skill type, or is a child skill!");
useDefaults = true;
break;
}
}
if (useDefaults) {
parentSkills.clear();
for (String name : config.getDefaults().getStringList(StringUtils.getCapitalized(skill.name()))) {
/* We do less checks in here because it's from inside our jar.
* If they're dedicated enough to have modified it, they can have the errors it may produce.
* Alternatively, this can be used to allow child skills to be parent skills, provided there are no circular dependencies this is an advanced sort of configuration.
*/
parentSkills.add(PrimarySkillType.valueOf(name.toUpperCase()));
}
}
// Register them
for (PrimarySkillType parentSkill : parentSkills) {
plugin.debug("Registering " + parentSkill.name() + " as parent of " + skill.name());
FamilyTree.registerParent(skill, parentSkill);
}
}
FamilyTree.closeRegistration();
}
}

View File

@ -1,5 +1,6 @@
package com.gmail.nossr50.config; package com.gmail.nossr50.config;
import com.gmail.nossr50.mcMMO;
import com.google.common.io.Files; import com.google.common.io.Files;
import ninja.leaping.configurate.ConfigurationNode; import ninja.leaping.configurate.ConfigurationNode;
import ninja.leaping.configurate.commented.CommentedConfigurationNode; import ninja.leaping.configurate.commented.CommentedConfigurationNode;
@ -14,11 +15,12 @@ import java.io.InputStream;
/** /**
* Handles loading and cacheing configuration settings from a configurable compatible config file * Handles loading and cacheing configuration settings from a configurable compatible config file
*/ */
//@ConfigSerializable
public abstract class Config implements VersionedConfig, Unload { public abstract class Config implements VersionedConfig, Unload {
/* SETTINGS */ /* SETTINGS */
private boolean mergeNewKeys; private boolean mergeNewKeys; //Whether or not to merge keys found in the default config
private boolean removeOldKeys; //Whether or not to remove unused keys form the config
private boolean copyDefaults; //Whether or not to copy the default config when first creating the file
/* PATH VARS */ /* PATH VARS */
@ -160,8 +162,9 @@ public abstract class Config implements VersionedConfig, Unload {
/* /*
* Gen a Default config from inside the JAR * Gen a Default config from inside the JAR
*/ */
McmmoCore.getLogger().info("Preparing to copy internal resource file (in JAR) - "+FILE_RELATIVE_PATH); mcMMO.p.getLogger().info("Preparing to copy internal resource file (in JAR) - "+FILE_RELATIVE_PATH);
InputStream inputStream = McmmoCore.getResource(FILE_RELATIVE_PATH); //InputStream inputStream = McmmoCore.getResource(FILE_RELATIVE_PATH);
InputStream inputStream = mcMMO.p.getResource(FILE_RELATIVE_PATH);
byte[] buffer = new byte[inputStream.available()]; byte[] buffer = new byte[inputStream.available()];
inputStream.read(buffer); inputStream.read(buffer);
@ -172,7 +175,7 @@ public abstract class Config implements VersionedConfig, Unload {
//Wipe old default file on disk //Wipe old default file on disk
if (targetFile.exists() && deleteOld) if (targetFile.exists() && deleteOld)
{ {
McmmoCore.getLogger().info("Updating file " + relativeOutputPath); mcMMO.p.getLogger().info("Updating file " + relativeOutputPath);
targetFile.delete(); //Necessary? targetFile.delete(); //Necessary?
} }
@ -183,7 +186,7 @@ public abstract class Config implements VersionedConfig, Unload {
} }
Files.write(buffer, targetFile); Files.write(buffer, targetFile);
McmmoCore.getLogger().info("Created config file - " + relativeOutputPath); mcMMO.p.getLogger().info("Created config file - " + relativeOutputPath);
inputStream.close(); //Close the input stream inputStream.close(); //Close the input stream
@ -225,10 +228,10 @@ public abstract class Config implements VersionedConfig, Unload {
* MainConfig will have any missing nodes inserted with their default value * MainConfig will have any missing nodes inserted with their default value
*/ */
public void readConfig() { public void readConfig() {
McmmoCore.getLogger().info("Attempting to read " + FILE_RELATIVE_PATH + "."); mcMMO.p.getLogger().info("Attempting to read " + FILE_RELATIVE_PATH + ".");
int version = this.userRootNode.getNode("ConfigVersion").getInt(); int version = this.userRootNode.getNode("ConfigVersion").getInt();
McmmoCore.getLogger().info(FILE_RELATIVE_PATH + " version is " + version); mcMMO.p.getLogger().info(FILE_RELATIVE_PATH + " version is " + version);
//Update our config //Update our config
updateConfig(); updateConfig();
@ -239,8 +242,8 @@ public abstract class Config implements VersionedConfig, Unload {
*/ */
private void updateConfig() private void updateConfig()
{ {
McmmoCore.getLogger().info(defaultRootNode.getChildrenMap().size() +" items in default children map"); mcMMO.p.getLogger().info(defaultRootNode.getChildrenMap().size() +" items in default children map");
McmmoCore.getLogger().info(userRootNode.getChildrenMap().size() +" items in default root map"); mcMMO.p.getLogger().info(userRootNode.getChildrenMap().size() +" items in default root map");
// Merge Values from default // Merge Values from default
if(mergeNewKeys) if(mergeNewKeys)
@ -259,13 +262,27 @@ public abstract class Config implements VersionedConfig, Unload {
} }
} }
/**
* Finds any keys in the users config that are not present in the default config and removes them
*/
private void removeOldKeys()
{
if(!removeOldKeys)
return;
for(ConfigurationNode configurationNode : defaultRootNode.getChildrenList())
{
}
}
/** /**
* Saves the current state information of the config to the users copy (which they may edit) * Saves the current state information of the config to the users copy (which they may edit)
* @throws IOException * @throws IOException
*/ */
private void saveUserCopy() throws IOException private void saveUserCopy() throws IOException
{ {
McmmoCore.getLogger().info("Saving new node"); mcMMO.p.getLogger().info("Saving new node");
userCopyLoader.save(userRootNode); userCopyLoader.save(userRootNode);
} }
@ -275,7 +292,7 @@ public abstract class Config implements VersionedConfig, Unload {
private void updateConfigVersion() { private void updateConfigVersion() {
// Set a version for our config // Set a version for our config
this.userRootNode.getNode("ConfigVersion").setValue(getConfigVersion()); this.userRootNode.getNode("ConfigVersion").setValue(getConfigVersion());
McmmoCore.getLogger().info("Updated config to ["+getConfigVersion()+"] - " + FILE_RELATIVE_PATH); mcMMO.p.getLogger().info("Updated config to ["+getConfigVersion()+"] - " + FILE_RELATIVE_PATH);
} }
/** /**

View File

@ -1,15 +1,9 @@
package com.gmail.nossr50.config; package com.gmail.nossr50.config;
import com.gmail.nossr50.config.*;
import com.gmail.nossr50.config.collectionconfigs.CollectionClassType; import com.gmail.nossr50.config.collectionconfigs.CollectionClassType;
import com.gmail.nossr50.config.collectionconfigs.MultiConfigContainer; import com.gmail.nossr50.config.collectionconfigs.MultiConfigContainer;
import com.gmail.nossr50.config.mods.ArmorConfigManager;
import com.gmail.nossr50.config.mods.BlockConfigManager;
import com.gmail.nossr50.config.mods.EntityConfigManager;
import com.gmail.nossr50.config.mods.ToolConfigManager;
import com.gmail.nossr50.config.skills.alchemy.PotionConfig; import com.gmail.nossr50.config.skills.alchemy.PotionConfig;
import com.gmail.nossr50.config.treasure.TreasureConfig; import com.gmail.nossr50.config.treasure.TreasureConfig;
import com.gmail.nossr50.skills.child.ChildConfig;
import com.gmail.nossr50.skills.repair.repairables.Repairable; import com.gmail.nossr50.skills.repair.repairables.Repairable;
import com.gmail.nossr50.skills.repair.repairables.SimpleRepairableManager; import com.gmail.nossr50.skills.repair.repairables.SimpleRepairableManager;
import com.gmail.nossr50.skills.salvage.salvageables.Salvageable; import com.gmail.nossr50.skills.salvage.salvageables.Salvageable;
@ -56,6 +50,10 @@ public final class ConfigManager {
private SoundConfig soundConfig; private SoundConfig soundConfig;
private RankConfig rankConfig; private RankConfig rankConfig;
/* CONFIG ERRORS */
private ArrayList<String> configErrors; //Collect errors to whine about to server admins
public ConfigManager() public ConfigManager()
{ {
unloadables = new ArrayList<>(); unloadables = new ArrayList<>();

View File

@ -1,60 +0,0 @@
package com.gmail.nossr50.skills.child;
import com.gmail.nossr50.datatypes.skills.PrimarySkillType;
import com.gmail.nossr50.util.StringUtils;
import org.bukkit.configuration.file.YamlConfiguration;
import java.util.EnumSet;
public class ChildConfig extends AutoUpdateConfigLoader {
public ChildConfig() {
super("child.yml");
loadKeys();
}
@Override
protected void loadKeys() {
config.setDefaults(YamlConfiguration.loadConfiguration(plugin.getResourceAsReader("child.yml")));
FamilyTree.clearRegistrations(); // when reloading, need to clear statics
for (PrimarySkillType skill : PrimarySkillType.CHILD_SKILLS) {
plugin.debug("Finding parents of " + skill.name());
EnumSet<PrimarySkillType> parentSkills = EnumSet.noneOf(PrimarySkillType.class);
boolean useDefaults = false; // If we had an error we back out and use defaults
for (String name : config.getStringList(StringUtils.getCapitalized(skill.name()))) {
try {
PrimarySkillType parentSkill = PrimarySkillType.valueOf(name.toUpperCase());
FamilyTree.enforceNotChildSkill(parentSkill);
parentSkills.add(parentSkill);
}
catch (IllegalArgumentException ex) {
plugin.getLogger().warning(name + " is not a valid skill type, or is a child skill!");
useDefaults = true;
break;
}
}
if (useDefaults) {
parentSkills.clear();
for (String name : config.getDefaults().getStringList(StringUtils.getCapitalized(skill.name()))) {
/* We do less checks in here because it's from inside our jar.
* If they're dedicated enough to have modified it, they can have the errors it may produce.
* Alternatively, this can be used to allow child skills to be parent skills, provided there are no circular dependencies this is an advanced sort of configuration.
*/
parentSkills.add(PrimarySkillType.valueOf(name.toUpperCase()));
}
}
// Register them
for (PrimarySkillType parentSkill : parentSkills) {
plugin.debug("Registering " + parentSkill.name() + " as parent of " + skill.name());
FamilyTree.registerParent(skill, parentSkill);
}
}
FamilyTree.closeRegistration();
}
}

View File

@ -1,53 +1,33 @@
package com.gmail.nossr50.skills.child; package com.gmail.nossr50.skills.child;
import com.gmail.nossr50.datatypes.skills.PrimarySkillType; import com.gmail.nossr50.datatypes.skills.PrimarySkillType;
import com.google.common.collect.ImmutableList;
import com.google.common.collect.ImmutableSet;
import java.util.Collections; import java.util.*;
import java.util.EnumSet;
import java.util.HashMap;
import java.util.Set;
public class FamilyTree { public class FamilyTree {
private static HashMap<PrimarySkillType, Set<PrimarySkillType>> tree = new HashMap<PrimarySkillType, Set<PrimarySkillType>>(); static final ImmutableSet<PrimarySkillType> salvageTree;
static final ImmutableSet<PrimarySkillType> smeltingTree;
static {
ArrayList<PrimarySkillType> salvageParentsList = new ArrayList<>();
ArrayList<PrimarySkillType> smeltingParentsList = new ArrayList<>();
salvageParentsList.add(PrimarySkillType.FISHING);
salvageParentsList.add(PrimarySkillType.REPAIR);
smeltingParentsList.add(PrimarySkillType.MINING);
smeltingParentsList.add(PrimarySkillType.REPAIR);
salvageTree = ImmutableSet.copyOf(salvageParentsList);
smeltingTree = ImmutableSet.copyOf(smeltingParentsList);
}
public static Set<PrimarySkillType> getParents(PrimarySkillType childSkill) { public static Set<PrimarySkillType> getParents(PrimarySkillType childSkill) {
enforceChildSkill(childSkill); if(childSkill == PrimarySkillType.SALVAGE)
return salvageTree;
// We do not check if we have the child skill in question, as not having it would mean we did something wrong, and an NPE is desired. else
return tree.get(childSkill); return smeltingTree;
}
protected static void registerParent(PrimarySkillType childSkill, PrimarySkillType parentSkill) {
enforceChildSkill(childSkill);
enforceNotChildSkill(parentSkill);
if (!tree.containsKey(childSkill)) {
tree.put(childSkill, EnumSet.noneOf(PrimarySkillType.class));
}
tree.get(childSkill).add(parentSkill);
}
protected static void closeRegistration() {
for (PrimarySkillType childSkill : tree.keySet()) {
Set<PrimarySkillType> immutableSet = Collections.unmodifiableSet(tree.get(childSkill));
tree.put(childSkill, immutableSet);
}
}
protected static void clearRegistrations() {
tree.clear();
}
protected static void enforceChildSkill(PrimarySkillType skill) {
if (!skill.isChildSkill()) {
throw new IllegalArgumentException(skill.name() + " is not a child skill!");
}
}
protected static void enforceNotChildSkill(PrimarySkillType skill) {
if (skill.isChildSkill()) {
throw new IllegalArgumentException(skill.name() + " is a child skill!");
}
} }
} }

View File

@ -1,15 +0,0 @@
#
# mcMMO child skill configuration
#
# You do not need to modify this file except to change parents of child skills
#
# If you wish a child skill to be the parent of another child skill, you must also make your changes to the child.yml within the jar
# WARNING: THIS IS NOT SUPPORTED, IF YOU DO SO YOU ARE RESPONSIBLE FOR THE ISSUES THAT MAY ARISE. That said, watch out for circular dependencies, those are bad.
#
#####
Salvage:
- Fishing
- Repair
Smelting:
- Mining
- Repair