Command system finished with #21!

This commit is contained in:
Norbi Peti 2016-06-25 10:48:24 +02:00
parent 718f43e303
commit cc574c3450
9 changed files with 59 additions and 21 deletions

View file

@ -246,7 +246,7 @@ public class PlayerListener implements Listener {
@EventHandler @EventHandler
public void onPlayerChat(AsyncPlayerChatEvent event) { public void onPlayerChat(AsyncPlayerChatEvent event) {
if (event.isCancelled()) // TODO: Change FactionChat to /tellraw if (event.isCancelled())
return; return;
event.setCancelled(ChatProcessing.ProcessChat(event.getPlayer(), event.setCancelled(ChatProcessing.ProcessChat(event.getPlayer(),
event.getMessage())); event.getMessage()));

View file

@ -3,6 +3,7 @@ package io.github.norbipeti.thebuttonmcchat.commands;
import io.github.norbipeti.thebuttonmcchat.PluginMain; import io.github.norbipeti.thebuttonmcchat.PluginMain;
import java.lang.reflect.Modifier; import java.lang.reflect.Modifier;
import java.util.ArrayList;
import java.util.Arrays; import java.util.Arrays;
import java.util.HashMap; import java.util.HashMap;
import java.util.Set; import java.util.Set;
@ -87,7 +88,7 @@ public class CommandCaller implements CommandExecutor {
TBMCCommandBase cmd = commands.get(path); TBMCCommandBase cmd = commands.get(path);
int argc = 0; int argc = 0;
while (cmd == null && path.contains("/")) { while (cmd == null && path.contains("/")) {
path = path.substring(0, path.indexOf('/')); path = path.substring(0, path.lastIndexOf('/'));
argc++; argc++;
cmd = commands.get(path); cmd = commands.get(path);
System.out.println(path); System.out.println(path);
@ -100,12 +101,31 @@ public class CommandCaller implements CommandExecutor {
"§cInternal error: Command not registered to CommandCaller"); "§cInternal error: Command not registered to CommandCaller");
return true; return true;
} }
if (cmd.GetPlayerOnly() && sender == Bukkit.getConsoleSender()) {
sender.sendMessage("§cOnly ingame players can use this command.");
return true;
}
if (!cmd.OnCommand( if (!cmd.OnCommand(
sender, sender,
alias, alias,
(args.length > 0 ? Arrays.copyOfRange(args, argc, (args.length > 0 ? Arrays.copyOfRange(args, args.length - argc,
args.length - 1) : args))) args.length) : args)))
sender.sendMessage(cmd.GetHelpText(alias)); sender.sendMessage(cmd.GetHelpText(alias));
return true; return true;
} }
public static String[] GetSubCommands(TBMCCommandBase command) {
ArrayList<String> cmds = new ArrayList<String>();
cmds.add("§6---- Subcommands ----");
for (TBMCCommandBase cmd : CommandCaller.GetCommands().values()) {
if (cmd.GetCommandPath().startsWith(command.GetCommandPath() + "/")) {
int ind = cmd.GetCommandPath().indexOf('/',
command.GetCommandPath().length() + 2);
if (ind >= 0)
continue;
cmds.add(cmd.GetCommandPath().replace('/', ' '));
}
}
return cmds.toArray(new String[cmds.size()]);
}
} }

View file

@ -21,7 +21,7 @@ public final class HelpCommand extends UCommandBase {
sender.sendMessage(new String[] { sender.sendMessage(new String[] {
"§6---- TBMC Help ----", "§6---- TBMC Help ----",
"Do /u help <topic> for more info", "Do /u help <topic> for more info",
"Alternatively, you can do /u help <commandname> [subcommands] for more info about a command", "Do /u help <commandname> [subcommands] for more info about a command",
"Topics:", "Topics:",
"flairs: The flairs are the numbers near your name", "flairs: The flairs are the numbers near your name",
"commands: See all the commands from this plugin", "commands: See all the commands from this plugin",
@ -32,12 +32,11 @@ public final class HelpCommand extends UCommandBase {
sender.sendMessage(new String[] { "§6---- About flairs ----", "" }); // TODO sender.sendMessage(new String[] { "§6---- About flairs ----", "" }); // TODO
else if (args[0].equalsIgnoreCase("commands")) { else if (args[0].equalsIgnoreCase("commands")) {
ArrayList<String> text = new ArrayList<String>(); ArrayList<String> text = new ArrayList<String>();
int i = 0; text.add("§6---- Command list ----");
text.set(i++, "§6---- Command list ----");
for (TBMCCommandBase cmd : CommandCaller.GetCommands().values()) for (TBMCCommandBase cmd : CommandCaller.GetCommands().values())
if (!cmd.GetCommandPath().contains("/")) if (!cmd.GetCommandPath().contains("/"))
text.set(i++, "/" + cmd.GetCommandPath()); text.add("/" + cmd.GetCommandPath());
sender.sendMessage((String[]) text.toArray()); sender.sendMessage(text.toArray(new String[text.size()]));
} else { } else {
String path = args[0]; String path = args[0];
for (int i = 1; i < args.length; i++) for (int i = 1; i < args.length; i++)
@ -57,4 +56,9 @@ public final class HelpCommand extends UCommandBase {
public String GetUCommandPath() { public String GetUCommandPath() {
return "help"; return "help";
} }
@Override
public boolean GetPlayerOnly() {
return false;
}
} }

View file

@ -1,5 +1,8 @@
package io.github.norbipeti.thebuttonmcchat.commands.ucmds; package io.github.norbipeti.thebuttonmcchat.commands.ucmds;
import java.util.ArrayList;
import io.github.norbipeti.thebuttonmcchat.commands.CommandCaller;
import io.github.norbipeti.thebuttonmcchat.commands.TBMCCommandBase; import io.github.norbipeti.thebuttonmcchat.commands.TBMCCommandBase;
import org.bukkit.command.CommandSender; import org.bukkit.command.CommandSender;
@ -8,8 +11,7 @@ public final class UCommand extends TBMCCommandBase {
@Override @Override
public String[] GetHelpText(String alias) { public String[] GetHelpText(String alias) {
return new String[] { "§6---- U commands ----", return CommandCaller.GetSubCommands(this);
"Subcommands: help, accept, ignore, admin" }; // TODO
} }
@Override @Override

View file

@ -8,10 +8,10 @@ public abstract class UCommandBase extends TBMCCommandBase {
@Override @Override
public String GetCommandPath() { public String GetCommandPath() {
return "u/" + GetUCommandPath(); //TODO: This for others return "u/" + GetUCommandPath();
} }
public abstract String GetUCommandPath(); // TODO: Help for /u commands public abstract String GetUCommandPath();
@Override @Override
public boolean GetPlayerOnly() { public boolean GetPlayerOnly() {

View file

@ -1,5 +1,6 @@
package io.github.norbipeti.thebuttonmcchat.commands.ucmds.admin; package io.github.norbipeti.thebuttonmcchat.commands.ucmds.admin;
import io.github.norbipeti.thebuttonmcchat.commands.CommandCaller;
import io.github.norbipeti.thebuttonmcchat.commands.ucmds.UCommandBase; import io.github.norbipeti.thebuttonmcchat.commands.ucmds.UCommandBase;
import org.bukkit.command.CommandSender; import org.bukkit.command.CommandSender;
@ -8,13 +9,11 @@ public final class AdminCommand extends UCommandBase {
@Override @Override
public String[] GetHelpText(String alias) { public String[] GetHelpText(String alias) {
return new String[] { "§6---- Admin ----", return CommandCaller.GetSubCommands(this);
"These commands are for mods only.", "Subcommands: reload, " }; // TODO
} }
@Override @Override
public boolean OnCommand(CommandSender sender, String alias, public boolean OnCommand(CommandSender sender, String alias, String[] args) {
String[] args) {
return false; return false;
} }
@ -22,4 +21,9 @@ public final class AdminCommand extends UCommandBase {
public String GetUCommandPath() { public String GetUCommandPath() {
return "admin"; return "admin";
} }
@Override
public boolean GetPlayerOnly() {
return false;
}
} }

View file

@ -4,7 +4,7 @@ import io.github.norbipeti.thebuttonmcchat.commands.ucmds.UCommandBase;
public abstract class AdminCommandBase extends UCommandBase { public abstract class AdminCommandBase extends UCommandBase {
public abstract String[] GetHelpText(String alias); public abstract String[] GetHelpText(String alias); //TODO: Require permissionű
@Override @Override
public String GetUCommandPath() { public String GetUCommandPath() {

View file

@ -1,5 +1,6 @@
package io.github.norbipeti.thebuttonmcchat.commands.ucmds.announce; package io.github.norbipeti.thebuttonmcchat.commands.ucmds.announce;
import io.github.norbipeti.thebuttonmcchat.commands.CommandCaller;
import io.github.norbipeti.thebuttonmcchat.commands.ucmds.UCommandBase; import io.github.norbipeti.thebuttonmcchat.commands.ucmds.UCommandBase;
import org.bukkit.command.CommandSender; import org.bukkit.command.CommandSender;
@ -8,8 +9,7 @@ public class AnnounceCommand extends UCommandBase {
@Override @Override
public String[] GetHelpText(String alias) { public String[] GetHelpText(String alias) {
return new String[] { "§6---- Announce ----", return CommandCaller.GetSubCommands(this);
"Subcommands: add, settime, remove, list, edit" }; // TODO
} }
@Override @Override
@ -22,4 +22,8 @@ public class AnnounceCommand extends UCommandBase {
return "announce"; return "announce";
} }
@Override
public boolean GetPlayerOnly() {
return false;
}
} }

View file

@ -8,9 +8,13 @@ public abstract class AnnounceCommandBase extends UCommandBase {
@Override @Override
public String GetUCommandPath() { public String GetUCommandPath() {
return "announce"; return "announce/" + GetAnnounceCommandPath();
} }
public abstract String GetAnnounceCommandPath(); public abstract String GetAnnounceCommandPath();
@Override
public boolean GetPlayerOnly() {
return false;
}
} }