From 15e81cf551facaee9e808b598655a6cf1274ffb1 Mon Sep 17 00:00:00 2001 From: Thinkofdeath Date: Sun, 25 Jan 2015 15:17:48 +0000 Subject: SPIGOT-449: Fix the wrong caller being used in chain execute commands --- nms-patches/CommandExecute.patch | 23 ++++++++++++++--------- 1 file changed, 14 insertions(+), 9 deletions(-) (limited to 'nms-patches/CommandExecute.patch') diff --git a/nms-patches/CommandExecute.patch b/nms-patches/CommandExecute.patch index 5c42ada0..a0373aa5 100644 --- a/nms-patches/CommandExecute.patch +++ b/nms-patches/CommandExecute.patch @@ -1,14 +1,17 @@ ---- ../work/decompile-8eb82bde//net/minecraft/server/CommandExecute.java 2015-01-04 23:24:40.781538505 +0000 -+++ src/main/java/net/minecraft/server/CommandExecute.java 2015-01-04 23:24:40.781538505 +0000 -@@ -2,6 +2,7 @@ +--- ../work/decompile-8eb82bde//net/minecraft/server/CommandExecute.java 2015-01-25 15:16:56.720837314 +0000 ++++ src/main/java/net/minecraft/server/CommandExecute.java 2015-01-25 15:16:56.720837314 +0000 +@@ -2,6 +2,10 @@ import java.util.Collection; import java.util.List; ++// CraftBukkit start +import org.bukkit.craftbukkit.command.ProxiedNativeCommandSender; ++import org.bukkit.craftbukkit.command.VanillaCommandWrapper; ++// CraftBukkit end public class CommandExecute extends CommandAbstract { -@@ -19,7 +20,7 @@ +@@ -19,7 +23,7 @@ return "commands.execute.usage"; } @@ -17,7 +20,7 @@ if (astring.length < 5) { throw new ExceptionUsage("commands.execute.usage", new Object[0]); } else { -@@ -52,12 +53,28 @@ +@@ -52,12 +56,30 @@ ICommandHandler icommandhandler = MinecraftServer.getServer().getCommandHandler(); try { @@ -25,12 +28,14 @@ - + // CraftBukkit start + org.bukkit.command.CommandSender sender = null; -+ if (icommandlistener.f() != null) { -+ sender = icommandlistener.f().getBukkitEntity(); -+ } else if (icommandlistener instanceof DedicatedServer) { ++ if (icommandlistener instanceof DedicatedServer) { + sender = MinecraftServer.getServer().server.getConsoleSender(); + } else if (icommandlistener instanceof TileEntityCommandListener) { + sender = ((TileEntityCommandListener) icommandlistener).sender; ++ } else if (VanillaCommandWrapper.lastSender != null) { ++ sender = VanillaCommandWrapper.lastSender; ++ }else if (icommandlistener.f() != null) { ++ sender = icommandlistener.f().getBukkitEntity(); + } else { + throw new CommandException("Unhandled executor " + icommandlistener.getClass().getSimpleName(), new Object[0]); + } @@ -48,7 +53,7 @@ throw new CommandException("commands.execute.failed", new Object[] { s, entity.getName()}); } } -@@ -70,4 +87,11 @@ +@@ -70,4 +92,11 @@ public boolean isListStart(String[] astring, int i) { return i == 0; } -- cgit v1.2.3