1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859 |
- 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();
- }
- }
|