diff options
author | Alexdoru <57050655+Alexdoru@users.noreply.github.com> | 2024-09-01 20:07:38 +0200 |
---|---|---|
committer | GitHub <noreply@github.com> | 2024-09-01 18:07:38 +0000 |
commit | dabef0411496dfe3dddfefc3a374aa1e3b56615e (patch) | |
tree | 4fea25a3d1dd3adac1fac09b6ee817688cde1aaf /src/main/java/kubatech/commands/CommandHandler.java | |
parent | dda0f8bb1ed2211b2df492d7bd53751e47de305f (diff) | |
download | GT5-Unofficial-dabef0411496dfe3dddfefc3a374aa1e3b56615e.tar.gz GT5-Unofficial-dabef0411496dfe3dddfefc3a374aa1e3b56615e.tar.bz2 GT5-Unofficial-dabef0411496dfe3dddfefc3a374aa1e3b56615e.zip |
Change how kubatech commands are registered (#3012)
rename child command map
add click event to open the file on the CommandBees chat message
remove command registration non sense
Co-authored-by: boubou19 <miisterunknown@gmail.com>
Diffstat (limited to 'src/main/java/kubatech/commands/CommandHandler.java')
-rw-r--r-- | src/main/java/kubatech/commands/CommandHandler.java | 78 |
1 files changed, 27 insertions, 51 deletions
diff --git a/src/main/java/kubatech/commands/CommandHandler.java b/src/main/java/kubatech/commands/CommandHandler.java index b0957c9572..e3d93534c5 100644 --- a/src/main/java/kubatech/commands/CommandHandler.java +++ b/src/main/java/kubatech/commands/CommandHandler.java @@ -25,10 +25,6 @@ import static kubatech.commands.CommandHandler.Translations.GENERIC_HELP; import static kubatech.commands.CommandHandler.Translations.INVALID; import static kubatech.commands.CommandHandler.Translations.USAGE; -import java.lang.annotation.ElementType; -import java.lang.annotation.Retention; -import java.lang.annotation.RetentionPolicy; -import java.lang.annotation.Target; import java.util.Arrays; import java.util.Collections; import java.util.HashMap; @@ -42,8 +38,6 @@ import net.minecraft.util.ChatComponentTranslation; import net.minecraft.util.EnumChatFormatting; import net.minecraft.util.StatCollector; -import kubatech.kubatech; - public class CommandHandler extends CommandBase { enum Translations { @@ -78,8 +72,18 @@ public class CommandHandler extends CommandBase { } } - private static final List<String> aliases = Collections.singletonList("kt"); - public static final HashMap<String, ICommand> commands = new HashMap<>(); + public static final HashMap<String, ICommand> childCommands = new HashMap<>(); + + static { + registerChildCommand(new CommandBees()); + registerChildCommand(new CommandConfig()); + registerChildCommand(new CommandHelp()); + registerChildCommand(new CommandTea()); + } + + private static void registerChildCommand(ICommand command) { + childCommands.put(command.getCommandName(), command); + } @Override public String getCommandName() { @@ -87,70 +91,42 @@ public class CommandHandler extends CommandBase { } @Override - public String getCommandUsage(ICommandSender p_71518_1_) { + public String getCommandUsage(ICommandSender sender) { return "kubatech " + USAGE.get(); } @SuppressWarnings("rawtypes") @Override public List getCommandAliases() { - return aliases; + return Collections.singletonList("kt"); } @Override - public void processCommand(ICommandSender p_71515_1_, String[] p_71515_2_) { - if (p_71515_1_.getEntityWorld().isRemote) return; - if (p_71515_2_.length == 0) { - p_71515_1_.addChatMessage(new ChatComponentText(INVALID.get(getCommandUsage(p_71515_1_)))); - p_71515_1_.addChatMessage(new ChatComponentText(GENERIC_HELP.get())); + public void processCommand(ICommandSender sender, String[] args) { + if (sender.getEntityWorld().isRemote) return; + if (args.length == 0) { + sender.addChatMessage(new ChatComponentText(INVALID.get(getCommandUsage(sender)))); + sender.addChatMessage(new ChatComponentText(GENERIC_HELP.get())); return; } - if (!commands.containsKey(p_71515_2_[0])) { - p_71515_1_.addChatMessage(new ChatComponentText(CANT_FIND.get(p_71515_2_[0]))); - p_71515_1_.addChatMessage(new ChatComponentText(GENERIC_HELP.get())); + if (!childCommands.containsKey(args[0])) { + sender.addChatMessage(new ChatComponentText(CANT_FIND.get(args[0]))); + sender.addChatMessage(new ChatComponentText(GENERIC_HELP.get())); return; } - ICommand cmd = commands.get(p_71515_2_[0]); - if (!cmd.canCommandSenderUseCommand(p_71515_1_)) { + ICommand cmd = childCommands.get(args[0]); + if (!cmd.canCommandSenderUseCommand(sender)) { ChatComponentTranslation chatcomponenttranslation2 = new ChatComponentTranslation( "commands.generic.permission"); chatcomponenttranslation2.getChatStyle() .setColor(EnumChatFormatting.RED); - p_71515_1_.addChatMessage(chatcomponenttranslation2); - } else cmd.processCommand( - p_71515_1_, - p_71515_2_.length > 1 ? Arrays.copyOfRange(p_71515_2_, 1, p_71515_2_.length) : new String[0]); + sender.addChatMessage(chatcomponenttranslation2); + } else cmd.processCommand(sender, args.length > 1 ? Arrays.copyOfRange(args, 1, args.length) : new String[0]); } @Override - public boolean canCommandSenderUseCommand(ICommandSender p_71519_1_) { + public boolean canCommandSenderUseCommand(ICommandSender sender) { return true; } - public static void addCommand(ICommand command) { - commands.put(command.getCommandName(), command); - } - - static { - String ChildCommandDesc = "L" + ChildCommand.class.getName() - .replace(".", "/") + ";"; - kubatech.myClasses.stream() - .filter( - clazz -> clazz.invisibleAnnotations != null && clazz.invisibleAnnotations.stream() - .anyMatch(ann -> ann.desc.equals(ChildCommandDesc))) - .forEach(clazz -> { - try { - addCommand( - (ICommand) Class.forName(clazz.name.replace("/", ".")) - .getConstructor() - .newInstance()); - } catch (Exception e) { - throw new RuntimeException(e); - } - }); - } - - @Target(ElementType.TYPE) - @Retention(RetentionPolicy.CLASS) - public @interface ChildCommand {} } |