mirror of
https://github.com/PaperMC/Paper.git
synced 2025-01-16 14:33:09 +01:00
Allow old behavior for CommandRegisteredEvent (#8249)
This commit is contained in:
parent
2782b0c375
commit
b9991242f3
4 changed files with 104 additions and 26 deletions
|
@ -5,5 +5,10 @@ import com.mojang.brigadier.suggestion.SuggestionProvider;
|
||||||
|
|
||||||
import java.util.function.Predicate;
|
import java.util.function.Predicate;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Brigadier {@link Command}, {@link SuggestionProvider}, and permission checker for Bukkit {@link Command}s.
|
||||||
|
*
|
||||||
|
* @param <S> command source type
|
||||||
|
*/
|
||||||
public interface BukkitBrigadierCommand <S extends BukkitBrigadierCommandSource> extends Command<S>, Predicate<S>, SuggestionProvider<S> {
|
public interface BukkitBrigadierCommand <S extends BukkitBrigadierCommandSource> extends Command<S>, Predicate<S>, SuggestionProvider<S> {
|
||||||
}
|
}
|
||||||
|
|
|
@ -13,12 +13,11 @@ import org.bukkit.event.server.ServerEvent;
|
||||||
import org.jetbrains.annotations.NotNull;
|
import org.jetbrains.annotations.NotNull;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Fired anytime the server synchronizes Bukkit CommandMap to Brigadier.
|
* Fired anytime the server synchronizes Bukkit commands to Brigadier.
|
||||||
*
|
*
|
||||||
* Allows a plugin to control the Literal and Argument nodes for this command to be
|
* Allows a plugin to control the command node structure for its commands.
|
||||||
* sent to the client.
|
* This is done at Plugin Enable time after commands have been registered, but may also
|
||||||
* This is done at Plugin Enable time after commands have been registered, but some
|
* run at a later point in the server lifetime due to plugins, a server reload, etc.
|
||||||
* plugins may use reflection to retrigger this rebuild during runtime.
|
|
||||||
*
|
*
|
||||||
* @deprecated Draft API - Subject to change until confirmed solves desired use cases
|
* @deprecated Draft API - Subject to change until confirmed solves desired use cases
|
||||||
*/
|
*/
|
||||||
|
@ -33,6 +32,7 @@ public class CommandRegisteredEvent <S extends BukkitBrigadierCommandSource> ext
|
||||||
private final RootCommandNode<S> root;
|
private final RootCommandNode<S> root;
|
||||||
private final ArgumentCommandNode<S, String> defaultArgs;
|
private final ArgumentCommandNode<S, String> defaultArgs;
|
||||||
private LiteralCommandNode<S> literal;
|
private LiteralCommandNode<S> literal;
|
||||||
|
private boolean rawCommand = false;
|
||||||
private boolean cancelled = false;
|
private boolean cancelled = false;
|
||||||
|
|
||||||
public CommandRegisteredEvent(String commandLabel, BukkitBrigadierCommand<S> brigadierCommand, Command command, RootCommandNode<S> root, LiteralCommandNode<S> literal, ArgumentCommandNode<S, String> defaultArgs) {
|
public CommandRegisteredEvent(String commandLabel, BukkitBrigadierCommand<S> brigadierCommand, Command command, RootCommandNode<S> root, LiteralCommandNode<S> literal, ArgumentCommandNode<S, String> defaultArgs) {
|
||||||
|
@ -45,55 +45,99 @@ public class CommandRegisteredEvent <S extends BukkitBrigadierCommandSource> ext
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @return The command name being registered
|
* Gets the command label of the {@link Command} being registered.
|
||||||
|
*
|
||||||
|
* @return the command label
|
||||||
*/
|
*/
|
||||||
public String getCommandLabel() {
|
public String getCommandLabel() {
|
||||||
return commandLabel;
|
return this.commandLabel;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @return The Bukkit API Brigadier Wrapped Command Object to handle executions and suggestions
|
* Gets the {@link BukkitBrigadierCommand} for the {@link Command} being registered. This can be used
|
||||||
|
* as the {@link com.mojang.brigadier.Command command executor} or
|
||||||
|
* {@link com.mojang.brigadier.suggestion.SuggestionProvider} of a {@link com.mojang.brigadier.tree.CommandNode}
|
||||||
|
* to delegate to the {@link Command} being registered.
|
||||||
|
*
|
||||||
|
* @return the {@link BukkitBrigadierCommand}
|
||||||
*/
|
*/
|
||||||
public BukkitBrigadierCommand<S> getBrigadierCommand() {
|
public BukkitBrigadierCommand<S> getBrigadierCommand() {
|
||||||
return brigadierCommand;
|
return this.brigadierCommand;
|
||||||
}
|
|
||||||
|
|
||||||
public Command getCommand() {
|
|
||||||
return command;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @return Gets the root command node being used to register a command to.
|
* Gets the {@link Command} being registered.
|
||||||
|
*
|
||||||
|
* @return the {@link Command}
|
||||||
|
*/
|
||||||
|
public Command getCommand() {
|
||||||
|
return this.command;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Gets the {@link RootCommandNode} which is being registered to.
|
||||||
|
*
|
||||||
|
* @return the {@link RootCommandNode}
|
||||||
*/
|
*/
|
||||||
public RootCommandNode<S> getRoot() {
|
public RootCommandNode<S> getRoot() {
|
||||||
return root;
|
return this.root;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Returns the Bukkit API's default handling of Arguments, if you wish to reuse it.
|
* Gets the Bukkit APIs default arguments node (greedy string), for if
|
||||||
* @return
|
* you wish to reuse it.
|
||||||
|
*
|
||||||
|
* @return default arguments node
|
||||||
*/
|
*/
|
||||||
public ArgumentCommandNode<S, String> getDefaultArgs() {
|
public ArgumentCommandNode<S, String> getDefaultArgs() {
|
||||||
return defaultArgs;
|
return this.defaultArgs;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Returns the Bukkit API's default literal for this command, including the {@link #getDefaultArgs()} as a child already.
|
* Gets the {@link LiteralCommandNode} to be registered for the {@link Command}.
|
||||||
* @return
|
*
|
||||||
|
* @return the {@link LiteralCommandNode}
|
||||||
*/
|
*/
|
||||||
public LiteralCommandNode<S> getLiteral() {
|
public LiteralCommandNode<S> getLiteral() {
|
||||||
return literal;
|
return this.literal;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Changes the literal used to register this command. The previous literable is mutable, so this is primarily if
|
* Sets the {@link LiteralCommandNode} used to register this command. The default literal is mutable, so
|
||||||
* you want to completely replace the object.
|
* this is primarily if you want to completely replace the object.
|
||||||
* @param literal
|
*
|
||||||
|
* @param literal new node
|
||||||
*/
|
*/
|
||||||
public void setLiteral(LiteralCommandNode<S> literal) {
|
public void setLiteral(LiteralCommandNode<S> literal) {
|
||||||
this.literal = literal;
|
this.literal = literal;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Gets whether this command should is treated as "raw".
|
||||||
|
*
|
||||||
|
* @see #setRawCommand(boolean)
|
||||||
|
* @return whether this command is treated as "raw"
|
||||||
|
*/
|
||||||
|
public boolean isRawCommand() {
|
||||||
|
return this.rawCommand;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Sets whether this command should be treated as "raw".
|
||||||
|
*
|
||||||
|
* <p>A "raw" command will only use the node provided by this event for
|
||||||
|
* sending the command tree to the client. For execution purposes, the default
|
||||||
|
* greedy string execution of a standard Bukkit {@link Command} is used.</p>
|
||||||
|
*
|
||||||
|
* <p>On older versions of Paper, this was the default and only behavior of this
|
||||||
|
* event.</p>
|
||||||
|
*
|
||||||
|
* @param rawCommand whether this command should be treated as "raw"
|
||||||
|
*/
|
||||||
|
public void setRawCommand(final boolean rawCommand) {
|
||||||
|
this.rawCommand = rawCommand;
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* {@inheritDoc}
|
* {@inheritDoc}
|
||||||
*/
|
*/
|
||||||
|
|
|
@ -45,7 +45,7 @@ index 0000000000000000000000000000000000000000..00000000000000000000000000000000
|
||||||
+ boolean registeredAskServerSuggestionsForTree = false; // Paper - tell clients to ask server for suggestions for EntityArguments
|
+ boolean registeredAskServerSuggestionsForTree = false; // Paper - tell clients to ask server for suggestions for EntityArguments
|
||||||
while (iterator.hasNext()) {
|
while (iterator.hasNext()) {
|
||||||
CommandNode<CommandSourceStack> commandnode2 = (CommandNode) iterator.next();
|
CommandNode<CommandSourceStack> commandnode2 = (CommandNode) iterator.next();
|
||||||
if ( !org.spigotmc.SpigotConfig.sendNamespaced && commandnode2.getName().contains( ":" ) ) continue; // Spigot
|
// Paper start
|
||||||
@@ -0,0 +0,0 @@ public class Commands {
|
@@ -0,0 +0,0 @@ public class Commands {
|
||||||
|
|
||||||
if (requiredargumentbuilder.getSuggestionsProvider() != null) {
|
if (requiredargumentbuilder.getSuggestionsProvider() != null) {
|
||||||
|
|
|
@ -21,6 +21,18 @@ index 0000000000000000000000000000000000000000..00000000000000000000000000000000
|
||||||
// Paper start
|
// Paper start
|
||||||
implementation("org.jline:jline-terminal-jansi:3.21.0")
|
implementation("org.jline:jline-terminal-jansi:3.21.0")
|
||||||
implementation("net.minecrell:terminalconsoleappender:1.3.0")
|
implementation("net.minecrell:terminalconsoleappender:1.3.0")
|
||||||
|
diff --git a/src/main/java/com/mojang/brigadier/tree/CommandNode.java b/src/main/java/com/mojang/brigadier/tree/CommandNode.java
|
||||||
|
index 0000000000000000000000000000000000000000..0000000000000000000000000000000000000000 100644
|
||||||
|
--- a/src/main/java/com/mojang/brigadier/tree/CommandNode.java
|
||||||
|
+++ b/src/main/java/com/mojang/brigadier/tree/CommandNode.java
|
||||||
|
@@ -0,0 +0,0 @@ public abstract class CommandNode<S> implements Comparable<CommandNode<S>> {
|
||||||
|
private final RedirectModifier<S> modifier;
|
||||||
|
private final boolean forks;
|
||||||
|
private Command<S> command;
|
||||||
|
+ public LiteralCommandNode<CommandSourceStack> clientNode = null; // Paper
|
||||||
|
// CraftBukkit start
|
||||||
|
public void removeCommand(String name) {
|
||||||
|
this.children.remove(name);
|
||||||
diff --git a/src/main/java/net/minecraft/commands/CommandSourceStack.java b/src/main/java/net/minecraft/commands/CommandSourceStack.java
|
diff --git a/src/main/java/net/minecraft/commands/CommandSourceStack.java b/src/main/java/net/minecraft/commands/CommandSourceStack.java
|
||||||
index 0000000000000000000000000000000000000000..0000000000000000000000000000000000000000 100644
|
index 0000000000000000000000000000000000000000..0000000000000000000000000000000000000000 100644
|
||||||
--- a/src/main/java/net/minecraft/commands/CommandSourceStack.java
|
--- a/src/main/java/net/minecraft/commands/CommandSourceStack.java
|
||||||
|
@ -81,6 +93,18 @@ index 0000000000000000000000000000000000000000..00000000000000000000000000000000
|
||||||
PlayerCommandSendEvent event = new PlayerCommandSendEvent(player.getBukkitEntity(), new LinkedHashSet<>(bukkit));
|
PlayerCommandSendEvent event = new PlayerCommandSendEvent(player.getBukkitEntity(), new LinkedHashSet<>(bukkit));
|
||||||
event.getPlayer().getServer().getPluginManager().callEvent(event);
|
event.getPlayer().getServer().getPluginManager().callEvent(event);
|
||||||
|
|
||||||
|
@@ -0,0 +0,0 @@ public class Commands {
|
||||||
|
|
||||||
|
while (iterator.hasNext()) {
|
||||||
|
CommandNode<CommandSourceStack> commandnode2 = (CommandNode) iterator.next();
|
||||||
|
+ // Paper start
|
||||||
|
+ if (commandnode2.clientNode != null) {
|
||||||
|
+ commandnode2 = commandnode2.clientNode;
|
||||||
|
+ }
|
||||||
|
+ // Paper end
|
||||||
|
if ( !org.spigotmc.SpigotConfig.sendNamespaced && commandnode2.getName().contains( ":" ) ) continue; // Spigot
|
||||||
|
|
||||||
|
if (commandnode2.canUse(source)) {
|
||||||
diff --git a/src/main/java/net/minecraft/server/network/ServerGamePacketListenerImpl.java b/src/main/java/net/minecraft/server/network/ServerGamePacketListenerImpl.java
|
diff --git a/src/main/java/net/minecraft/server/network/ServerGamePacketListenerImpl.java b/src/main/java/net/minecraft/server/network/ServerGamePacketListenerImpl.java
|
||||||
index 0000000000000000000000000000000000000000..0000000000000000000000000000000000000000 100644
|
index 0000000000000000000000000000000000000000..0000000000000000000000000000000000000000 100644
|
||||||
--- a/src/main/java/net/minecraft/server/network/ServerGamePacketListenerImpl.java
|
--- a/src/main/java/net/minecraft/server/network/ServerGamePacketListenerImpl.java
|
||||||
|
@ -139,6 +163,7 @@ index 0000000000000000000000000000000000000000..00000000000000000000000000000000
|
||||||
+ // Paper start - Expose Brigadier to Paper-MojangAPI
|
+ // Paper start - Expose Brigadier to Paper-MojangAPI
|
||||||
+ com.mojang.brigadier.tree.RootCommandNode<CommandSourceStack> root = dispatcher.getRoot();
|
+ com.mojang.brigadier.tree.RootCommandNode<CommandSourceStack> root = dispatcher.getRoot();
|
||||||
+ LiteralCommandNode<CommandSourceStack> literal = LiteralArgumentBuilder.<CommandSourceStack>literal(label).requires(this).executes(this).build();
|
+ LiteralCommandNode<CommandSourceStack> literal = LiteralArgumentBuilder.<CommandSourceStack>literal(label).requires(this).executes(this).build();
|
||||||
|
+ LiteralCommandNode<CommandSourceStack> defaultNode = literal;
|
||||||
+ com.mojang.brigadier.tree.ArgumentCommandNode<CommandSourceStack, String> defaultArgs = RequiredArgumentBuilder.<CommandSourceStack, String>argument("args", StringArgumentType.greedyString()).suggests(this).executes(this).build();
|
+ com.mojang.brigadier.tree.ArgumentCommandNode<CommandSourceStack, String> defaultArgs = RequiredArgumentBuilder.<CommandSourceStack, String>argument("args", StringArgumentType.greedyString()).suggests(this).executes(this).build();
|
||||||
+ literal.addChild(defaultArgs);
|
+ literal.addChild(defaultArgs);
|
||||||
+ com.destroystokyo.paper.event.brigadier.CommandRegisteredEvent<CommandSourceStack> event = new com.destroystokyo.paper.event.brigadier.CommandRegisteredEvent<>(label, this, this.command, root, literal, defaultArgs);
|
+ com.destroystokyo.paper.event.brigadier.CommandRegisteredEvent<CommandSourceStack> event = new com.destroystokyo.paper.event.brigadier.CommandRegisteredEvent<>(label, this, this.command, root, literal, defaultArgs);
|
||||||
|
@ -146,6 +171,10 @@ index 0000000000000000000000000000000000000000..00000000000000000000000000000000
|
||||||
+ return null;
|
+ return null;
|
||||||
+ }
|
+ }
|
||||||
+ literal = event.getLiteral();
|
+ literal = event.getLiteral();
|
||||||
|
+ if (event.isRawCommand()) {
|
||||||
|
+ defaultNode.clientNode = literal;
|
||||||
|
+ literal = defaultNode;
|
||||||
|
+ }
|
||||||
+ root.addChild(literal);
|
+ root.addChild(literal);
|
||||||
+ return literal;
|
+ return literal;
|
||||||
+ // Paper end
|
+ // Paper end
|
||||||
|
|
Loading…
Reference in a new issue