From 8e712bc8276e0675fe404459e0dcf6d553d4100b Mon Sep 17 00:00:00 2001 From: Josh Roy <10731363+JRoy@users.noreply.github.com> Date: Tue, 8 Jun 2021 19:42:45 -0400 Subject: [PATCH] Fix empty paths with Configurate (#4214) --- .../java/com/earth2me/essentials/Warps.java | 2 +- .../config/EssentialsConfiguration.java | 18 ++++++++++-------- 2 files changed, 11 insertions(+), 9 deletions(-) diff --git a/Essentials/src/main/java/com/earth2me/essentials/Warps.java b/Essentials/src/main/java/com/earth2me/essentials/Warps.java index c4dd46c85..334f3fe1c 100644 --- a/Essentials/src/main/java/com/earth2me/essentials/Warps.java +++ b/Essentials/src/main/java/com/earth2me/essentials/Warps.java @@ -126,7 +126,7 @@ public class Warps implements IConf, net.ess3.api.IWarps { final EssentialsConfiguration conf = new EssentialsConfiguration(listOfFile); conf.load(); final String name = conf.getString("name", null); - if (name != null) { + if (name != null && conf.hasProperty("world")) { warpPoints.put(new StringIgnoreCase(name), conf); } } catch (final Exception ex) { diff --git a/Essentials/src/main/java/com/earth2me/essentials/config/EssentialsConfiguration.java b/Essentials/src/main/java/com/earth2me/essentials/config/EssentialsConfiguration.java index e136b8392..95c05f7ac 100644 --- a/Essentials/src/main/java/com/earth2me/essentials/config/EssentialsConfiguration.java +++ b/Essentials/src/main/java/com/earth2me/essentials/config/EssentialsConfiguration.java @@ -105,7 +105,6 @@ public class EssentialsConfiguration { } public void setProperty(String path, final Location location) { - path = path == null ? "" : path; setInternal(path, LazyLocation.fromLocation(location)); } @@ -265,7 +264,7 @@ public class EssentialsConfiguration { } public CommentedConfigurationNode getSection(final String path) { - final CommentedConfigurationNode node = configurationNode.node(toSplitRoot(path)); + final CommentedConfigurationNode node = toSplitRoot(path, configurationNode); if (node.virtual()) { return null; } @@ -297,14 +296,14 @@ public class EssentialsConfiguration { private void setInternal(final String path, final Object value) { try { - configurationNode.node(toSplitRoot(path)).set(value); + toSplitRoot(path, configurationNode).set(value); } catch (SerializationException e) { LOGGER.log(Level.SEVERE, e.getMessage(), e); } } private CommentedConfigurationNode getInternal(final String path) { - final CommentedConfigurationNode node = configurationNode.node(toSplitRoot(path)); + final CommentedConfigurationNode node = toSplitRoot(path, configurationNode); if (node.virtual()) { return null; } @@ -312,12 +311,15 @@ public class EssentialsConfiguration { } public boolean hasProperty(final String path) { - return !configurationNode.node(toSplitRoot(path)).isNull(); + return !toSplitRoot(path, configurationNode).isNull(); } - public Object[] toSplitRoot(String node) { - node = node.startsWith(".") ? node.substring(1) : node; - return node.contains(".") ? node.split("\\.") : new Object[]{node}; + public CommentedConfigurationNode toSplitRoot(String path, final CommentedConfigurationNode node) { + if (path == null) { + return node; + } + path = path.startsWith(".") ? path.substring(1) : path; + return node.node(path.contains(".") ? path.split("\\.") : new Object[]{path}); } public synchronized void load() {