Listed arguments
Arguments have a setting that determines whether or not they are present in the CommandArguments args
that is populated when executing a command.
By default, the LiteralArgument
has this setting set to false
, hence the literal values are not present in the CommandArguments args
.
This flag is set using the following function:
java
Argument setListed(boolean listed);
Example - Setting listed arguments
Example - Setting listed arguments
Say we have the following command:
mccmd
/mycommand <player> <value> <message>
Let's also say that in our implementation of this command, we don't actually perform any processing for <value>
. Hence, listing it in the CommandArguments args
is unnecessary.
java
new CommandAPICommand("mycommand")
.withArguments(new PlayerArgument("player"))
.withArguments(new IntegerArgument("value").setListed(false))
.withArguments(new GreedyStringArgument("message"))
.executes((sender, args) -> {
// args == [player, message]
Player player = (Player) args.get("player");
String message = (String) args.get("message"); // Note that the IntegerArgument is not available in the CommandArguments
player.sendMessage(message);
})
.register();
In this scenario, the argument <value>
is not present in the CommandArguments args
for the executor.