From 46c820e7477e2abe9e4191df85336a461275173e Mon Sep 17 00:00:00 2001 From: Bukkit/Spigot Date: Mon, 10 Jul 2017 21:05:39 +1000 Subject: [PATCH] SPIGOT-3409: Improve performance of registering stupid amounts of permissions in plugin.yml By: md_5 --- .../bukkit/plugin/SimplePluginManager.java | 25 +++++++++++++++---- 1 file changed, 20 insertions(+), 5 deletions(-) diff --git a/paper-api/src/main/java/org/bukkit/plugin/SimplePluginManager.java b/paper-api/src/main/java/org/bukkit/plugin/SimplePluginManager.java index 00fa781554..2dae74e7bb 100644 --- a/paper-api/src/main/java/org/bukkit/plugin/SimplePluginManager.java +++ b/paper-api/src/main/java/org/bukkit/plugin/SimplePluginManager.java @@ -589,6 +589,11 @@ public final class SimplePluginManager implements PluginManager { } public void addPermission(Permission perm) { + addPermission(perm, true); + } + + @Deprecated + public void addPermission(Permission perm, boolean dirty) { String name = perm.getName().toLowerCase(java.util.Locale.ENGLISH); if (permissions.containsKey(name)) { @@ -596,7 +601,7 @@ public final class SimplePluginManager implements PluginManager { } permissions.put(name, perm); - calculatePermissionDefault(perm); + calculatePermissionDefault(perm, dirty); } public Set getDefaultPermissions(boolean op) { @@ -616,21 +621,31 @@ public final class SimplePluginManager implements PluginManager { defaultPerms.get(true).remove(perm); defaultPerms.get(false).remove(perm); - calculatePermissionDefault(perm); + calculatePermissionDefault(perm, true); } } - private void calculatePermissionDefault(Permission perm) { + private void calculatePermissionDefault(Permission perm, boolean dirty) { if ((perm.getDefault() == PermissionDefault.OP) || (perm.getDefault() == PermissionDefault.TRUE)) { defaultPerms.get(true).add(perm); - dirtyPermissibles(true); + if (dirty) { + dirtyPermissibles(true); + } } if ((perm.getDefault() == PermissionDefault.NOT_OP) || (perm.getDefault() == PermissionDefault.TRUE)) { defaultPerms.get(false).add(perm); - dirtyPermissibles(false); + if (dirty) { + dirtyPermissibles(false); + } } } + @Deprecated + public void dirtyPermissibles() { + dirtyPermissibles(true); + dirtyPermissibles(false); + } + private void dirtyPermissibles(boolean op) { Set permissibles = getDefaultPermSubscriptions(op);