summaryrefslogtreecommitdiffstats
path: root/src
diff options
context:
space:
mode:
Diffstat (limited to 'src')
-rw-r--r--src/main/java/org/bukkit/plugin/PluginDescriptionFile.java25
1 files changed, 13 insertions, 12 deletions
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<Permission> 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<Permission> getPermissions() {
+ if (permissions == null) {
+ if (lazyPermissions == null) {
+ permissions = ImmutableList.<Permission>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.<Permission>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) {