From 07a80cec7fdc6173549c51d00c262cfd35a61be1 Mon Sep 17 00:00:00 2001 From: CraftBukkit/Spigot Date: Mon, 21 Mar 2016 18:51:07 -0400 Subject: [PATCH] Only create PermissibleBase instance in CraftEntity the first time it is actually needed. Fixes static test cases for subclasses failing when perm field was instantiated. By: Matthew --- .../craftbukkit/entity/CraftEntity.java | 57 +++++++++++-------- 1 file changed, 32 insertions(+), 25 deletions(-) diff --git a/paper-server/src/main/java/org/bukkit/craftbukkit/entity/CraftEntity.java b/paper-server/src/main/java/org/bukkit/craftbukkit/entity/CraftEntity.java index 27c1851a38..5572ac1d3c 100644 --- a/paper-server/src/main/java/org/bukkit/craftbukkit/entity/CraftEntity.java +++ b/paper-server/src/main/java/org/bukkit/craftbukkit/entity/CraftEntity.java @@ -25,18 +25,7 @@ import org.bukkit.plugin.Plugin; import org.bukkit.util.Vector; public abstract class CraftEntity implements org.bukkit.entity.Entity { - private static final PermissibleBase perm = new PermissibleBase(new ServerOperator() { - - @Override - public boolean isOp() { - return false; - } - - @Override - public void setOp(boolean value) { - - } - }); + private static PermissibleBase perm; protected final CraftServer server; protected Entity entity; @@ -487,67 +476,67 @@ public abstract class CraftEntity implements org.bukkit.entity.Entity { @Override public boolean isPermissionSet(String name) { - return perm.isPermissionSet(name); + return getPermissibleBase().isPermissionSet(name); } @Override public boolean isPermissionSet(Permission perm) { - return CraftEntity.perm.isPermissionSet(perm); + return CraftEntity.getPermissibleBase().isPermissionSet(perm); } @Override public boolean hasPermission(String name) { - return perm.hasPermission(name); + return getPermissibleBase().hasPermission(name); } @Override public boolean hasPermission(Permission perm) { - return this.perm.hasPermission(perm); + return getPermissibleBase().hasPermission(perm); } @Override public PermissionAttachment addAttachment(Plugin plugin, String name, boolean value) { - return perm.addAttachment(plugin, name, value); + return getPermissibleBase().addAttachment(plugin, name, value); } @Override public PermissionAttachment addAttachment(Plugin plugin) { - return perm.addAttachment(plugin); + return getPermissibleBase().addAttachment(plugin); } @Override public PermissionAttachment addAttachment(Plugin plugin, String name, boolean value, int ticks) { - return perm.addAttachment(plugin, name, value, ticks); + return getPermissibleBase().addAttachment(plugin, name, value, ticks); } @Override public PermissionAttachment addAttachment(Plugin plugin, int ticks) { - return perm.addAttachment(plugin, ticks); + return getPermissibleBase().addAttachment(plugin, ticks); } @Override public void removeAttachment(PermissionAttachment attachment) { - perm.removeAttachment(attachment); + getPermissibleBase().removeAttachment(attachment); } @Override public void recalculatePermissions() { - perm.recalculatePermissions(); + getPermissibleBase().recalculatePermissions(); } @Override public Set getEffectivePermissions() { - return perm.getEffectivePermissions(); + return getPermissibleBase().getEffectivePermissions(); } @Override public boolean isOp() { - return perm.isOp(); + return getPermissibleBase().isOp(); } @Override public void setOp(boolean value) { - perm.setOp(value); + getPermissibleBase().setOp(value); } @Override @@ -563,4 +552,22 @@ public abstract class CraftEntity implements org.bukkit.entity.Entity { public boolean isGlowing() { return getHandle().glowing; } + + private static PermissibleBase getPermissibleBase() { + if (perm == null) { + perm = new PermissibleBase(new ServerOperator() { + + @Override + public boolean isOp() { + return false; + } + + @Override + public void setOp(boolean value) { + + } + }); + } + return perm; + } }