From 1cbbdebfe3987946a0632cb499d1c1040868207a Mon Sep 17 00:00:00 2001 From: Bukkit/Spigot Date: Sat, 10 Mar 2012 15:05:59 -0600 Subject: [PATCH] [Bleeding] Lazily calculate permissions. Addresses BUKKIT-1122 By: Wesley Wolfe --- .../bukkit/plugin/PluginDescriptionFile.java | 25 ++++++++++--------- 1 file changed, 13 insertions(+), 12 deletions(-) diff --git a/paper-api/src/main/java/org/bukkit/plugin/PluginDescriptionFile.java b/paper-api/src/main/java/org/bukkit/plugin/PluginDescriptionFile.java index 1b68db4600..21858eb50b 100644 --- a/paper-api/src/main/java/org/bukkit/plugin/PluginDescriptionFile.java +++ b/paper-api/src/main/java/org/bukkit/plugin/PluginDescriptionFile.java @@ -34,6 +34,7 @@ public final class PluginDescriptionFile { private boolean database = false; private PluginLoadOrder order = PluginLoadOrder.POSTWORLD; private List permissions = null; + private Map lazyPermissions = null; private PermissionDefault defaultPerm = PermissionDefault.OP; public PluginDescriptionFile(final InputStream stream) throws InvalidDescriptionException { @@ -150,6 +151,14 @@ public final class PluginDescriptionFile { } public List getPermissions() { + if (permissions == null) { + if (lazyPermissions == null) { + permissions = ImmutableList.of(); + } else { + permissions = ImmutableList.copyOf(Permission.loadPermissions(lazyPermissions, "Permission node '%s' in plugin description file for " + getFullName() + " is invalid", defaultPerm)); + lazyPermissions = null; + } + } return permissions; } @@ -315,18 +324,10 @@ public final class PluginDescriptionFile { } } - if (map.get("permissions") != null) { - try { - Map perms = (Map) map.get("permissions"); - - permissions = ImmutableList.copyOf(Permission.loadPermissions(perms, "Permission node '%s' in plugin description file for " + getFullName() + " is invalid", defaultPerm)); - } catch (ClassCastException ex) { - throw new InvalidDescriptionException(ex, "permissions are of wrong type"); - } catch (NullPointerException ex) { - throw new InvalidDescriptionException(ex, "permissions are not properly defined"); - } - } else { - permissions = ImmutableList.of(); + try { + lazyPermissions = (Map) map.get("permissions"); + } catch (ClassCastException ex) { + throw new InvalidDescriptionException(ex, "permissions are of the wrong type"); } if (map.get("prefix") != null) {