From 2e01621c63cf2a62a238093f2b69ff759d59200c Mon Sep 17 00:00:00 2001 From: Wesley Wolfe Date: Sat, 10 Mar 2012 15:05:59 -0600 Subject: [Bleeding] Lazily calculate permissions. Addresses BUKKIT-1122 --- .../org/bukkit/plugin/PluginDescriptionFile.java | 25 +++++++++++----------- 1 file changed, 13 insertions(+), 12 deletions(-) (limited to 'src/main/java') diff --git a/src/main/java/org/bukkit/plugin/PluginDescriptionFile.java b/src/main/java/org/bukkit/plugin/PluginDescriptionFile.java index 1b68db46..21858eb5 100644 --- a/src/main/java/org/bukkit/plugin/PluginDescriptionFile.java +++ b/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) { -- cgit v1.2.3