craftbukkit/nms-patches/net/minecraft/commands/CommandDispatcher.patch

164 lines
7.6 KiB
Diff
Raw Normal View History

2021-03-16 09:00:00 +11:00
--- a/net/minecraft/commands/CommandDispatcher.java
+++ b/net/minecraft/commands/CommandDispatcher.java
2022-07-28 04:00:00 +10:00
@@ -109,6 +109,14 @@
2022-03-01 02:00:00 +11:00
import net.minecraft.util.profiling.jfr.JvmProfiler;
import org.slf4j.Logger;
2018-07-15 10:00:00 +10:00
+// CraftBukkit start
+import com.google.common.base.Joiner;
2020-06-25 10:00:00 +10:00
+import java.util.Collection;
+import java.util.LinkedHashSet;
+import org.bukkit.event.player.PlayerCommandSendEvent;
2018-07-15 10:00:00 +10:00
+import org.bukkit.event.server.ServerCommandEvent;
+// CraftBukkit end
+
public class CommandDispatcher {
2022-03-01 02:00:00 +11:00
private static final Logger LOGGER = LogUtils.getLogger();
2022-07-28 04:00:00 +10:00
@@ -120,6 +128,7 @@
2021-06-11 15:00:00 +10:00
private final com.mojang.brigadier.CommandDispatcher<CommandListenerWrapper> dispatcher = new com.mojang.brigadier.CommandDispatcher();
2018-07-15 10:00:00 +10:00
2022-06-08 02:00:00 +10:00
public CommandDispatcher(CommandDispatcher.ServerType commanddispatcher_servertype, CommandBuildContext commandbuildcontext) {
2020-06-25 10:00:00 +10:00
+ this(); // CraftBukkit
2021-11-22 09:00:00 +11:00
CommandAdvancement.register(this.dispatcher);
CommandAttribute.register(this.dispatcher);
2022-06-08 02:00:00 +10:00
CommandExecute.register(this.dispatcher, commandbuildcontext);
2022-07-28 04:00:00 +10:00
@@ -204,6 +213,11 @@
2022-06-08 02:00:00 +10:00
CommandPublish.register(this.dispatcher);
}
2021-11-22 09:00:00 +11:00
+ // CraftBukkit start
2018-07-15 10:00:00 +10:00
+ }
+
+ public CommandDispatcher() {
2021-11-22 09:00:00 +11:00
+ // CraftBukkkit end
this.dispatcher.setConsumer((commandcontext, flag, i) -> {
((CommandListenerWrapper) commandcontext.getSource()).onCommandComplete(commandcontext, flag, i);
2018-07-15 10:00:00 +10:00
});
2022-07-28 04:00:00 +10:00
@@ -216,12 +230,59 @@
return new ParseResults(commandcontextbuilder1, parseresults.getReader(), parseresults.getExceptions());
2018-07-15 10:00:00 +10:00
}
2021-11-22 09:00:00 +11:00
+ // CraftBukkit start
2018-07-15 10:00:00 +10:00
+ public int dispatchServerCommand(CommandListenerWrapper sender, String command) {
+ Joiner joiner = Joiner.on(" ");
+ if (command.startsWith("/")) {
+ command = command.substring(1);
+ }
+
+ ServerCommandEvent event = new ServerCommandEvent(sender.getBukkitSender(), command);
+ org.bukkit.Bukkit.getPluginManager().callEvent(event);
+ if (event.isCancelled()) {
+ return 0;
+ }
+ command = event.getCommand();
+
+ String[] args = command.split(" ");
+
+ String cmd = args[0];
+ if (cmd.startsWith("minecraft:")) cmd = cmd.substring("minecraft:".length());
+ if (cmd.startsWith("bukkit:")) cmd = cmd.substring("bukkit:".length());
+
+ // Block disallowed commands
+ if (cmd.equalsIgnoreCase("stop") || cmd.equalsIgnoreCase("kick") || cmd.equalsIgnoreCase("op")
+ || cmd.equalsIgnoreCase("deop") || cmd.equalsIgnoreCase("ban") || cmd.equalsIgnoreCase("ban-ip")
+ || cmd.equalsIgnoreCase("pardon") || cmd.equalsIgnoreCase("pardon-ip") || cmd.equalsIgnoreCase("reload")) {
+ return 0;
+ }
+
+ // Handle vanilla commands;
2021-11-22 09:00:00 +11:00
+ if (sender.getLevel().getCraftServer().getCommandBlockOverride(args[0])) {
2018-07-15 10:00:00 +10:00
+ args[0] = "minecraft:" + args[0];
+ }
+
+ String newCommand = joiner.join(args);
2022-07-28 04:00:00 +10:00
+ return this.performPrefixedCommand(sender, newCommand, newCommand);
2018-07-15 10:00:00 +10:00
+ }
2022-06-08 02:00:00 +10:00
+ // CraftBukkit end
2018-07-15 10:00:00 +10:00
+
2022-06-08 02:00:00 +10:00
public int performPrefixedCommand(CommandListenerWrapper commandlistenerwrapper, String s) {
+ // CraftBukkit start
+ return this.performPrefixedCommand(commandlistenerwrapper, s, s);
+ }
+
+ public int performPrefixedCommand(CommandListenerWrapper commandlistenerwrapper, String s, String label) {
2022-07-28 04:00:00 +10:00
s = s.startsWith("/") ? s.substring(1) : s;
- return this.performCommand(this.dispatcher.parse(s, commandlistenerwrapper), s);
+ return this.performCommand(this.dispatcher.parse(s, commandlistenerwrapper), s, label);
2022-06-08 02:00:00 +10:00
+ // CraftBukkit end
}
2022-07-28 04:00:00 +10:00
public int performCommand(ParseResults<CommandListenerWrapper> parseresults, String s) {
+ return this.performCommand(parseresults, s, s);
+ }
+
2022-07-28 04:00:00 +10:00
+ public int performCommand(ParseResults<CommandListenerWrapper> parseresults, String s, String label) { // CraftBukkit
CommandListenerWrapper commandlistenerwrapper = (CommandListenerWrapper) parseresults.getContext().getSource();
2018-07-15 10:00:00 +10:00
2022-06-08 02:00:00 +10:00
commandlistenerwrapper.getServer().getProfiler().push(() -> {
2022-07-28 04:00:00 +10:00
@@ -246,7 +307,7 @@
2018-12-26 08:00:00 +11:00
if (commandsyntaxexception.getInput() != null && commandsyntaxexception.getCursor() >= 0) {
2018-07-15 10:00:00 +10:00
int j = Math.min(commandsyntaxexception.getInput().length(), commandsyntaxexception.getCursor());
2022-06-08 02:00:00 +10:00
IChatMutableComponent ichatmutablecomponent = IChatBaseComponent.empty().withStyle(EnumChatFormat.GRAY).withStyle((chatmodifier) -> {
- return chatmodifier.withClickEvent(new ChatClickable(ChatClickable.EnumClickAction.SUGGEST_COMMAND, "/" + s));
2021-11-22 09:00:00 +11:00
+ return chatmodifier.withClickEvent(new ChatClickable(ChatClickable.EnumClickAction.SUGGEST_COMMAND, label)); // CraftBukkit
2020-01-22 08:00:00 +11:00
});
2018-07-15 10:00:00 +10:00
2018-12-26 08:00:00 +11:00
if (j > 10) {
2022-07-28 04:00:00 +10:00
@@ -296,11 +357,36 @@
}
2021-11-22 09:00:00 +11:00
public void sendCommands(EntityPlayer entityplayer) {
2018-12-26 08:00:00 +11:00
- Map<CommandNode<CommandListenerWrapper>, CommandNode<ICompletionProvider>> map = Maps.newHashMap();
+ // CraftBukkit start
+ // Register Vanilla commands into builtRoot as before
2018-12-26 08:00:00 +11:00
+ Map<CommandNode<CommandListenerWrapper>, CommandNode<ICompletionProvider>> map = Maps.newIdentityHashMap(); // Use identity to prevent aliasing issues
+ RootCommandNode vanillaRoot = new RootCommandNode();
+
2021-11-22 09:00:00 +11:00
+ RootCommandNode<CommandListenerWrapper> vanilla = entityplayer.server.vanillaCommandDispatcher.getDispatcher().getRoot();
2018-12-26 08:00:00 +11:00
+ map.put(vanilla, vanillaRoot);
2021-11-22 09:00:00 +11:00
+ this.fillUsableCommands(vanilla, vanillaRoot, entityplayer.createCommandSourceStack(), (Map) map);
+
+ // Now build the global commands in a second pass
2018-12-26 08:00:00 +11:00
RootCommandNode<ICompletionProvider> rootcommandnode = new RootCommandNode();
2021-06-11 15:00:00 +10:00
map.put(this.dispatcher.getRoot(), rootcommandnode);
2021-11-22 09:00:00 +11:00
this.fillUsableCommands(this.dispatcher.getRoot(), rootcommandnode, entityplayer.createCommandSourceStack(), map);
+
+ Collection<String> bukkit = new LinkedHashSet<>();
+ for (CommandNode node : rootcommandnode.getChildren()) {
+ bukkit.add(node.getName());
+ }
+
+ PlayerCommandSendEvent event = new PlayerCommandSendEvent(entityplayer.getBukkitEntity(), new LinkedHashSet<>(bukkit));
+ event.getPlayer().getServer().getPluginManager().callEvent(event);
+
+ // Remove labels that were removed during the event
+ for (String orig : bukkit) {
+ if (!event.getCommands().contains(orig)) {
+ rootcommandnode.removeCommand(orig);
+ }
+ }
+ // CraftBukkit end
2021-11-22 09:00:00 +11:00
entityplayer.connection.send(new PacketPlayOutCommands(rootcommandnode));
}
2022-07-28 04:00:00 +10:00
@@ -311,7 +397,7 @@
2018-12-26 08:00:00 +11:00
CommandNode<CommandListenerWrapper> commandnode2 = (CommandNode) iterator.next();
if (commandnode2.canUse(commandlistenerwrapper)) {
- ArgumentBuilder<ICompletionProvider, ?> argumentbuilder = commandnode2.createBuilder();
+ ArgumentBuilder argumentbuilder = commandnode2.createBuilder(); // CraftBukkit - decompile error
argumentbuilder.requires((icompletionprovider) -> {
return true;
2022-07-28 04:00:00 +10:00
@@ -334,7 +420,7 @@
argumentbuilder.redirect((CommandNode) map.get(argumentbuilder.getRedirect()));
2018-12-26 08:00:00 +11:00
}
- CommandNode<ICompletionProvider> commandnode3 = argumentbuilder.build();
+ CommandNode commandnode3 = argumentbuilder.build(); // CraftBukkit - decompile error
map.put(commandnode2, commandnode3);
commandnode1.addChild(commandnode3);