From 384fbf5464331638f39a7725903e626cd6b37550 Mon Sep 17 00:00:00 2001 From: Luck Date: Mon, 21 Nov 2016 17:07:13 +0000 Subject: [PATCH] Revert: Use faster wildcard parsing method --- .../processors/WildcardProcessor.java | 29 ++++++++----------- .../calculators/SpongeWildcardProcessor.java | 29 ++++++++----------- 2 files changed, 24 insertions(+), 34 deletions(-) diff --git a/common/src/main/java/me/lucko/luckperms/common/calculators/processors/WildcardProcessor.java b/common/src/main/java/me/lucko/luckperms/common/calculators/processors/WildcardProcessor.java index 21f6a815..e460b498 100644 --- a/common/src/main/java/me/lucko/luckperms/common/calculators/processors/WildcardProcessor.java +++ b/common/src/main/java/me/lucko/luckperms/common/calculators/processors/WildcardProcessor.java @@ -26,32 +26,27 @@ import me.lucko.luckperms.api.Tristate; import me.lucko.luckperms.common.calculators.PermissionProcessor; import java.util.Map; -import java.util.regex.Pattern; public class WildcardProcessor implements PermissionProcessor { - private static final Pattern SPLIT = Pattern.compile("\\."); private Map map = null; @Override - public Tristate hasPermission(String s) { - if (s.startsWith(".") || !s.contains(".")) { - throw new IllegalArgumentException(); - } + public Tristate hasPermission(String permission) { + String node = permission; - String[] parts = SPLIT.split(s); - StringBuilder sb = new StringBuilder(); - - for (int i = parts.length - 2; i >= 0; i--) { - for (int i1 = 0; i1 <= i; i1++) { - sb.append(parts[i1]).append("."); + while (true) { + int endIndex = node.lastIndexOf('.'); + if (endIndex == -1) { + break; } - Boolean b = map.get(sb.append("*").toString()); - if (b != null) { - return Tristate.fromBoolean(b); + node = node.substring(0, endIndex); + if (!node.isEmpty()) { + Boolean b = map.get(node + ".*"); + if (b != null) { + return Tristate.fromBoolean(b); + } } - - sb.setLength(0); } Boolean b = map.get("'*'"); diff --git a/sponge/src/main/java/me/lucko/luckperms/sponge/calculators/SpongeWildcardProcessor.java b/sponge/src/main/java/me/lucko/luckperms/sponge/calculators/SpongeWildcardProcessor.java index 152306b5..39a226a0 100644 --- a/sponge/src/main/java/me/lucko/luckperms/sponge/calculators/SpongeWildcardProcessor.java +++ b/sponge/src/main/java/me/lucko/luckperms/sponge/calculators/SpongeWildcardProcessor.java @@ -26,32 +26,27 @@ import me.lucko.luckperms.api.Tristate; import me.lucko.luckperms.common.calculators.PermissionProcessor; import java.util.Map; -import java.util.regex.Pattern; public class SpongeWildcardProcessor implements PermissionProcessor { - private static final Pattern SPLIT = Pattern.compile("\\."); private Map map = null; @Override - public Tristate hasPermission(String s) { - if (s.startsWith(".") || !s.contains(".")) { - throw new IllegalArgumentException(); - } + public Tristate hasPermission(String permission) { + String node = permission; - String[] parts = SPLIT.split(s); - StringBuilder sb = new StringBuilder(); - - for (int i = parts.length - 2; i >= 0; i--) { - for (int i1 = 0; i1 <= i; i1++) { - sb.append(parts[i1]).append("."); + while (true) { + int endIndex = node.lastIndexOf('.'); + if (endIndex == -1) { + break; } - Boolean b = map.get(sb.deleteCharAt(sb.length() - 1).toString()); - if (b != null) { - return Tristate.fromBoolean(b); + node = node.substring(0, endIndex); + if (!node.isEmpty()) { + Boolean b = map.get(node); + if (b != null) { + return Tristate.fromBoolean(b); + } } - - sb.setLength(0); } return Tristate.UNDEFINED;