From 691c25561dc7a8e0d61fc2bcbfb68afe168e7348 Mon Sep 17 00:00:00 2001 From: CraftBukkit/Spigot Date: Fri, 26 May 2017 16:43:56 +1000 Subject: [PATCH] Ensure gameLoop function gets selectors applied. By: md_5 --- paper-server/nms-patches/CustomFunction.patch | 11 +++++ .../command/CraftFunctionCommandSender.java | 47 +++++++++++++++++++ .../command/VanillaCommandWrapper.java | 3 ++ 3 files changed, 61 insertions(+) create mode 100644 paper-server/nms-patches/CustomFunction.patch create mode 100644 paper-server/src/main/java/org/bukkit/craftbukkit/command/CraftFunctionCommandSender.java diff --git a/paper-server/nms-patches/CustomFunction.patch b/paper-server/nms-patches/CustomFunction.patch new file mode 100644 index 0000000000..b0429ae11e --- /dev/null +++ b/paper-server/nms-patches/CustomFunction.patch @@ -0,0 +1,11 @@ +--- a/net/minecraft/server/CustomFunction.java ++++ b/net/minecraft/server/CustomFunction.java +@@ -130,7 +130,7 @@ + } + + public void a(CustomFunctionData customfunctiondata, ICommandListener icommandlistener, ArrayDeque arraydeque, int i) { +- customfunctiondata.a().a(icommandlistener, this.a); ++ CommandBlockListenerAbstract.executeSafely(icommandlistener, new org.bukkit.craftbukkit.command.CraftFunctionCommandSender(icommandlistener), this.a); // CraftBukkit + } + + public String toString() { diff --git a/paper-server/src/main/java/org/bukkit/craftbukkit/command/CraftFunctionCommandSender.java b/paper-server/src/main/java/org/bukkit/craftbukkit/command/CraftFunctionCommandSender.java new file mode 100644 index 0000000000..6bb69bb41e --- /dev/null +++ b/paper-server/src/main/java/org/bukkit/craftbukkit/command/CraftFunctionCommandSender.java @@ -0,0 +1,47 @@ +package org.bukkit.craftbukkit.command; + +import net.minecraft.server.IChatBaseComponent; +import net.minecraft.server.ICommandListener; +import org.bukkit.craftbukkit.util.CraftChatMessage; + +public class CraftFunctionCommandSender extends ServerCommandSender { + + private final ICommandListener handle; + + public CraftFunctionCommandSender(ICommandListener handle) { + this.handle = handle; + } + + @Override + public void sendMessage(String message) { + for (IChatBaseComponent component : CraftChatMessage.fromString(message)) { + handle.sendMessage(component); + } + } + + @Override + public void sendMessage(String[] messages) { + for (String message : messages) { + sendMessage(message); + } + } + + @Override + public String getName() { + return handle.getName(); + } + + @Override + public boolean isOp() { + return true; + } + + @Override + public void setOp(boolean value) { + throw new UnsupportedOperationException("Cannot change operator status of server function sender"); + } + + public ICommandListener getHandle() { + return handle; + } +} diff --git a/paper-server/src/main/java/org/bukkit/craftbukkit/command/VanillaCommandWrapper.java b/paper-server/src/main/java/org/bukkit/craftbukkit/command/VanillaCommandWrapper.java index 14115fb561..03d29fe84c 100644 --- a/paper-server/src/main/java/org/bukkit/craftbukkit/command/VanillaCommandWrapper.java +++ b/paper-server/src/main/java/org/bukkit/craftbukkit/command/VanillaCommandWrapper.java @@ -158,6 +158,9 @@ public final class VanillaCommandWrapper extends Command { if (sender instanceof ProxiedCommandSender) { return ((ProxiedNativeCommandSender) sender).getHandle(); } + if (sender instanceof CraftFunctionCommandSender) { + return ((CraftFunctionCommandSender) sender).getHandle(); + } throw new IllegalArgumentException("Cannot make " + sender + " a vanilla command listener"); }