From a217727bb432e51e39b330b3a01af8316c972265 Mon Sep 17 00:00:00 2001 From: Luck Date: Tue, 30 Aug 2016 11:04:34 +0100 Subject: [PATCH] Match negative priorities and fix PEX weight migration --- .../subcommands/MigrationPermissionsEx.java | 14 ++++++-------- .../main/java/me/lucko/luckperms/utils/Node.java | 4 ++-- 2 files changed, 8 insertions(+), 10 deletions(-) diff --git a/common/src/main/java/me/lucko/luckperms/commands/migration/subcommands/MigrationPermissionsEx.java b/common/src/main/java/me/lucko/luckperms/commands/migration/subcommands/MigrationPermissionsEx.java index 86053c7f..c1cda223 100644 --- a/common/src/main/java/me/lucko/luckperms/commands/migration/subcommands/MigrationPermissionsEx.java +++ b/common/src/main/java/me/lucko/luckperms/commands/migration/subcommands/MigrationPermissionsEx.java @@ -128,11 +128,9 @@ public class MigrationPermissionsEx extends SubCommand { int groupCount = 0; for (PermissionGroup group : manager.getGroupList()) { + int groupWeight = group.getWeight() * -1; groupCount ++; - - if (group.getWeight() > maxGroupWeight) { - maxGroupWeight = group.getWeight(); - } + maxGroupWeight = Math.max(maxGroupWeight, groupWeight); final String name = group.getName().toLowerCase(); plugin.getDatastore().createAndLoadGroup(name); @@ -232,10 +230,10 @@ public class MigrationPermissionsEx extends SubCommand { if (prefix != null && !prefix.equals("")) { prefix = ArgumentChecker.escapeCharacters(prefix); try { - lpGroup.setPermission("prefix." + group.getWeight() + "." + prefix, true); + lpGroup.setPermission("prefix." + groupWeight + "." + prefix, true); LogEntry.build() .actor(Constants.getConsoleUUID()).actorName(Constants.getConsoleName()) - .acted(lpGroup).action("set prefix." + group.getWeight() + "." + prefix + " true") + .acted(lpGroup).action("set prefix." + groupWeight + "." + prefix + " true") .build().submit(plugin); } catch (Exception ex) { if (!(ex instanceof ObjectAlreadyHasException)) { @@ -247,10 +245,10 @@ public class MigrationPermissionsEx extends SubCommand { if (suffix != null && !suffix.equals("")) { suffix = ArgumentChecker.escapeCharacters(suffix); try { - lpGroup.setPermission("suffix." + group.getWeight() + "." + suffix, true); + lpGroup.setPermission("suffix." + groupWeight + "." + suffix, true); LogEntry.build() .actor(Constants.getConsoleUUID()).actorName(Constants.getConsoleName()) - .acted(lpGroup).action("set suffix." + group.getWeight() + "." + suffix + " true") + .acted(lpGroup).action("set suffix." + groupWeight + "." + suffix + " true") .build().submit(plugin); } catch (Exception ex) { if (!(ex instanceof ObjectAlreadyHasException)) { diff --git a/common/src/main/java/me/lucko/luckperms/utils/Node.java b/common/src/main/java/me/lucko/luckperms/utils/Node.java index e283b200..38a0ae82 100644 --- a/common/src/main/java/me/lucko/luckperms/utils/Node.java +++ b/common/src/main/java/me/lucko/luckperms/utils/Node.java @@ -38,8 +38,8 @@ import java.util.stream.Collectors; @ToString @EqualsAndHashCode public class Node implements me.lucko.luckperms.api.Node { - private static final Pattern PREFIX_PATTERN = Pattern.compile("(?i)prefix\\.\\d+\\..*"); - private static final Pattern SUFFIX_PATTERN = Pattern.compile("(?i)suffix\\.\\d+\\..*"); + private static final Pattern PREFIX_PATTERN = Pattern.compile("(?i)prefix\\.-?\\d+\\..*"); + private static final Pattern SUFFIX_PATTERN = Pattern.compile("(?i)suffix\\.-?\\d+\\..*"); public static me.lucko.luckperms.api.Node fromSerialisedNode(String s, Boolean b) { return builderFromSerialisedNode(s, b).build();