X - The return type post-serialisation.public interface Argument<X>
This class manages arguments for the . The key aspects are to check if an input is valid, convert it to a workable type and to provide completions for guidance.
| Modifier and Type | Method and Description | 
|---|---|
| @Nullable List<String> | getCompletions()A list of completions for this argument type. | 
| @NotNull String | getName()This is what your argument shows up as in a command. | 
| default Class<X> | getType() | 
| boolean | isPlural()Used by the system to determine if this argument accepts multiple inputs. | 
| boolean | isRequired()Used by the system when testing the command. | 
| boolean | matches(String string)This is your matcher, to check if the player's input is valid. | 
| X | serialise(String string)This should convert the player's input to a valid object. | 
| Argument<X> | setLabel(@NotNull String name)Ideally, this should set a field that will then be returned by  getName(). | 
| Argument<X> | setRequired(boolean boo)Ideally, this should set a field that will then be returned by  isRequired(). | 
@NotNull X serialise(String string)
matches(String) will be called first.
 Generally, throw an exception if something goes wrong.string - The passed argument.boolean matches(String string)
 For example: a material-accepting argument checks if the string matches a Material enum and, if so, if the enum is a block.
 In this case, "grass_block" would pass (Material.GRASS_BLOCK but "blob" and "diamond_sword" wouldn't as they are not materials/blocks respectively.
 
This should be a catch-all. If there is any chance of it not being valid, this should FAIL.
string - The player's input argument.@NotNull @NotNull String getName()
Good examples: "block", "material", "entity", "player"
Bad examples: "string" (one exists already), "<test>" (the brackets are added later), "something" (vague and unhelpful), "blocks like stone" (should be one word), "verylongcommandargument" (too long).
@Nullable @Nullable List<String> getCompletions()
boolean isPlural()
The command handler will automatically handle plural suggestions using comma separation.
Typical plurals: "stone,grass_block,dirt", "stone_stairs[facing=north],oak_log,stone_slab[half=top]"
boolean isRequired()
Argument<X> setRequired(boolean boo)
isRequired().
 This should ALWAYS default to true.
 
 Note: You may want to change the Argument returned to be of your implementing class type.
boo - True/false.Argument<X> setLabel(@NotNull @NotNull String name)
getName().
 
 Note: You may want to change the Argument returned to be of your implementing class type.
name - The label to be put [here];Copyright © 2020. All rights reserved.