tutorial:commands
Differences
This shows you the differences between two versions of the page.
Both sides previous revisionPrevious revisionNext revision | Previous revisionNext revisionBoth sides next revision | ||
tutorial:commands [2019/11/16 04:35] – liach | tutorial:commands [2020/05/07 20:12] – Amend to use new API i509vcb | ||
---|---|---|---|
Line 8: | Line 8: | ||
If you just want to see how to register commands you've come to the right place here. | If you just want to see how to register commands you've come to the right place here. | ||
- | Registering commands is done through '' | + | Registering commands is done by registering a new listener in the '' |
- | + | The event should be registered | |
- | The '' | + | |
- | + | ||
- | The dedicated flag if set to true will tell Fabric to only register the command on a '' | + | |
+ | The dedicated parameter if true will tell event listeners that the server commands are being registered on is a '' | ||
Below are a few examples of how the commands can be registered. | Below are a few examples of how the commands can be registered. | ||
<code java [enable_line_numbers=" | <code java [enable_line_numbers=" | ||
- | CommandRegistry.INSTANCE.register(false, dispatcher -> TutorialCommands.register(dispatcher)); // All commands are registered in a single class that references | + | // The actual registration of commands can be delegated to another class via a method reference |
- | + | CommandRegistrationCallback.EVENT.register(TutorialCommands::register); | |
- | CommandRegistry.INSTANCE.register(false, | + | |
- | | + | // Or you can define |
- | | + | CommandRegistrationCallback.EVENT.register((dispatcher, dedicated) |
+ | TutorialCommand.register(dispatcher); | ||
+ | | ||
+ | TutorialHelpCommand.register(dispatcher); | ||
+ | | ||
+ | IntegratedTutorialHelpCommand.register(dispatcher); | ||
+ | } | ||
}); | }); | ||
- | CommandRegistry.INSTANCE.register(true, dispatcher -> { // Or directly registering the command to the dispatcher. | + | CommandRegistrationCallback.EVENT.register((dispatcher, dedicated) |
dispatcher.register(LiteralArgumentBuilder.literal(" | dispatcher.register(LiteralArgumentBuilder.literal(" | ||
}); | }); | ||
Line 449: | Line 453: | ||
First create a class which extends '' | First create a class which extends '' | ||
- | <code java> | + | <code java [enable_line_numbers=" |
public class UUIDArgumentType implements ArgumentType< | public class UUIDArgumentType implements ArgumentType< | ||
</ | </ | ||
Line 463: | Line 467: | ||
Next you will store the current position of the cursor, this is so you can substring out only the specific argument. This will always be at the beginning of where your argument appears on the command line. | Next you will store the current position of the cursor, this is so you can substring out only the specific argument. This will always be at the beginning of where your argument appears on the command line. | ||
- | <code java> | + | <code java [enable_line_numbers=" |
int argBeginning = reader.getCursor(); | int argBeginning = reader.getCursor(); | ||
if (!reader.canRead()) { | if (!reader.canRead()) { | ||
Line 472: | Line 476: | ||
Now we grab the entire argument. Depending on your argument type, you may have a different criteria or be similar to some arguments where detecting a '' | Now we grab the entire argument. Depending on your argument type, you may have a different criteria or be similar to some arguments where detecting a '' | ||
- | <code java> | + | <code java [enable_line_numbers=" |
while (reader.canRead() && reader.peek() != ' ') { // peek provides the character at the current cursor position. | while (reader.canRead() && reader.peek() != ' ') { // peek provides the character at the current cursor position. | ||
reader.skip(); | reader.skip(); | ||
Line 480: | Line 484: | ||
Then we will ask the StringReader what the current position of the cursor is an substring our argument out of the command line. | Then we will ask the StringReader what the current position of the cursor is an substring our argument out of the command line. | ||
- | <code java> | + | <code java [enable_line_numbers=" |
Now finally we check if our argument is correct and parse the specific argument to our liking, and throwing an exception if the parsing fails. | Now finally we check if our argument is correct and parse the specific argument to our liking, and throwing an exception if the parsing fails. | ||
- | <code java> | + | <code java [enable_line_numbers=" |
try { | try { | ||
UUID uuid = UUID.fromString(uuidString); | UUID uuid = UUID.fromString(uuidString); | ||
Line 499: | Line 503: | ||
Within your ModInitializer (Not only client or server) you will add this so the client can recognize the argument when the command tree is sent. For more complex argument types, you may need to create your own ArgumentSerializer. | Within your ModInitializer (Not only client or server) you will add this so the client can recognize the argument when the command tree is sent. For more complex argument types, you may need to create your own ArgumentSerializer. | ||
- | <code java> | + | <code java [enable_line_numbers=" |
ArgumentTypes.register(" | ArgumentTypes.register(" | ||
// The argument should be what will create the ArgumentType. | // The argument should be what will create the ArgumentType. | ||
Line 506: | Line 510: | ||
And here is the whole ArgumentType: | And here is the whole ArgumentType: | ||
- | <file java UUIDArgumentType.java> | + | <file java UUIDArgumentType.java |
import com.mojang.brigadier.StringReader; | import com.mojang.brigadier.StringReader; |
tutorial/commands.txt · Last modified: 2024/02/23 14:22 by allen1210