New command system is getting ready

This commit is contained in:
Norbi Peti 2016-06-24 19:02:45 +02:00
parent b312f2358e
commit 2d7447a46f
5 changed files with 150 additions and 120 deletions

127
pom.xml
View file

@ -1,61 +1,68 @@
<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" <project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd"> xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
<modelVersion>4.0.0</modelVersion> <modelVersion>4.0.0</modelVersion>
<artifactId>TheButtonMCPlugin</artifactId> <artifactId>TheButtonMCPlugin</artifactId>
<version>0.0.1-SNAPSHOT</version> <version>0.0.1-SNAPSHOT</version>
<name>The Button Minecraft Plugin</name> <name>The Button Minecraft Plugin</name>
<description>The Button Minecraft Plugin</description> <description>The Button Minecraft Plugin</description>
<build> <build>
<sourceDirectory>src</sourceDirectory> <sourceDirectory>src</sourceDirectory>
<resources> <resources>
<resource> <resource>
<directory>src</directory> <directory>src</directory>
<excludes> <excludes>
<exclude>**/*.java</exclude> <exclude>**/*.java</exclude>
</excludes> </excludes>
</resource> </resource>
</resources> </resources>
<plugins> <plugins>
<plugin> <plugin>
<artifactId>maven-compiler-plugin</artifactId> <artifactId>maven-compiler-plugin</artifactId>
<version>3.3</version> <version>3.3</version>
<configuration> <configuration>
<source>1.7</source> <source>1.7</source>
<target>1.7</target> <target>1.7</target>
</configuration> </configuration>
</plugin> </plugin>
<plugin> <plugin>
<groupId>org.apache.maven.plugins</groupId> <groupId>org.apache.maven.plugins</groupId>
<artifactId>maven-shade-plugin</artifactId> <artifactId>maven-shade-plugin</artifactId>
<version>2.4.2</version> <version>2.4.2</version>
<executions> <executions>
<execution> <execution>
<phase>package</phase> <phase>package</phase>
<goals> <goals>
<goal>shade</goal> <goal>shade</goal>
</goals> </goals>
<configuration> <configuration>
<artifactSet> <artifactSet>
<excludes> <excludes>
<exclude>classworlds:classworlds</exclude> <exclude>classworlds:classworlds</exclude>
<exclude>junit:junit</exclude> <exclude>junit:junit</exclude>
<exclude>jmock:*</exclude> <exclude>jmock:*</exclude>
<exclude>*:xml-apis</exclude> <exclude>*:xml-apis</exclude>
<exclude>org.apache.maven:lib:tests</exclude> <exclude>org.apache.maven:lib:tests</exclude>
<exclude>log4j:log4j:jar:</exclude> <exclude>log4j:log4j:jar:</exclude>
</excludes> </excludes>
</artifactSet> </artifactSet>
</configuration> </configuration>
</execution> </execution>
</executions> </executions>
</plugin> </plugin>
</plugins> </plugins>
</build> </build>
<groupId>tk.sznp</groupId> <groupId>tk.sznp</groupId>
<repositories> <repositories>
<repository> <repository>
<id>spigot-repo</id> <id>spigot-repo</id>
<url>https://hub.spigotmc.org/nexus/content/repositories/snapshots/</url> <url>https://hub.spigotmc.org/nexus/content/repositories/snapshots/</url>
</repository> </repository>
</repositories> </repositories>
<dependencies>
<dependency>
<groupId>org.reflections</groupId>
<artifactId>reflections</artifactId>
<version>0.9.10</version>
</dependency>
</dependencies>
</project> </project>

View file

@ -0,0 +1,76 @@
package io.github.norbipeti.thebuttonmcchat.commands;
import io.github.norbipeti.thebuttonmcchat.PluginMain;
import java.util.HashMap;
import java.util.Set;
import org.bukkit.Bukkit;
import org.bukkit.command.Command;
import org.bukkit.command.CommandExecutor;
import org.bukkit.command.CommandSender;
import org.reflections.Reflections;
public class CommandCaller implements CommandExecutor {
private CommandCaller() {
}
private static HashMap<String, TBMCCommandBase> commands = new HashMap<String, TBMCCommandBase>();
private static HashMap<String, TBMCSubCommandBase> subcommands = new HashMap<String, TBMCSubCommandBase>();
public static void RegisterCommands(PluginMain plugin) {
System.out.println("Registering commands...");
Reflections rf = new Reflections(
"io.github.norbipeti.thebuttonmcchat.commands");
Set<Class<? extends TBMCCommandBase>> cmds = rf
.getSubTypesOf(TBMCCommandBase.class);
for (Class<? extends TBMCCommandBase> cmd : cmds) {
try {
TBMCCommandBase c = cmd.newInstance();
commands.put(c.GetCommandName(), c);
plugin.getCommand(c.GetCommandName()).setExecutor(c);
} catch (InstantiationException e) {
e.printStackTrace();
} catch (IllegalAccessException e) {
e.printStackTrace();
}
}
System.out.println("Registering subcommands...");
Set<Class<? extends TBMCSubCommandBase>> subcmds = rf
.getSubTypesOf(TBMCSubCommandBase.class);
for (Class<? extends TBMCSubCommandBase> subcmd : subcmds) {
try {
TBMCSubCommandBase sc = subcmd.newInstance();
subcommands.put(sc.GetCommandPath(), sc);
} catch (InstantiationException e) {
e.printStackTrace();
} catch (IllegalAccessException e) {
e.printStackTrace();
}
}
System.out.println("Done registering");
}
@Override
public boolean onCommand(CommandSender sender, Command command,
String alias, String[] args) {
// TODO: Test if path exists, if not,
// go up one level, and
// finally fallback to args.length==0
String path = command.getName();
for (String arg : args)
path += "/" + arg;
TBMCSubCommandBase cmd = subcommands.get(path);
while (cmd == null && path.contains("/"))
path = path.substring(0, path.indexOf('/'));
if (cmd == null) {
sender.sendMessage("§cInternal error: Subcommand not registered to CommandCaller");
if (sender != Bukkit.getConsoleSender())
Bukkit.getConsoleSender()
.sendMessage(
"§cInternal error: Subcommand not registered to CommandCaller");
return true;
}
return true;
}
}

View file

@ -13,47 +13,9 @@ import org.bukkit.command.CommandExecutor;
import org.bukkit.command.CommandSender; import org.bukkit.command.CommandSender;
import org.bukkit.entity.Player; import org.bukkit.entity.Player;
public abstract class TBMCCommandBase implements CommandExecutor { public abstract class TBMCCommandBase {
public static void RegisterCommands(PluginMain plugin) {
TBMCCommandBase cmd = new UCommand();
plugin.getCommand(cmd.GetCommandName()).setExecutor(cmd);
cmd = new OOCCommand();
plugin.getCommand(cmd.GetCommandName()).setExecutor(cmd);
cmd = new UnlolCommand();
plugin.getCommand(cmd.GetCommandName()).setExecutor(cmd);
cmd = new MWikiCommand();
plugin.getCommand(cmd.GetCommandName()).setExecutor(cmd);
cmd = new TableflipCommand();
plugin.getCommand(cmd.GetCommandName()).setExecutor(cmd);
cmd = new UnflipCommand();
plugin.getCommand(cmd.GetCommandName()).setExecutor(cmd);
cmd = new ChatonlyCommand();
plugin.getCommand(cmd.GetCommandName()).setExecutor(cmd);
cmd = new ShrugCommand();
plugin.getCommand(cmd.GetCommandName()).setExecutor(cmd);
}
private static HashMap<String, TBMCCommandBase> commands = new HashMap<String, TBMCCommandBase>();
public static HashMap<String, TBMCCommandBase> GetCommands() {
return commands;
}
public TBMCCommandBase() { public TBMCCommandBase() {
commands.put(GetCommandName(), this);
}
@Override
public boolean onCommand(CommandSender sender, Command cmd, String alias,
String[] args) {
if (GetPlayerOnly() && !(sender instanceof Player)) {
sender.sendMessage("§cError: You must be a player to use this command.");
return true;
}
if (!OnCommand(sender, alias, args))
sender.sendMessage(GetHelpText(alias));
return true;
} }
public abstract String[] GetHelpText(String alias); public abstract String[] GetHelpText(String alias);
@ -61,7 +23,7 @@ public abstract class TBMCCommandBase implements CommandExecutor {
public abstract boolean OnCommand(CommandSender sender, String alias, public abstract boolean OnCommand(CommandSender sender, String alias,
String[] args); String[] args);
public abstract String GetCommandName(); public abstract String GetCommandPath();
public abstract boolean GetPlayerOnly(); public abstract boolean GetPlayerOnly();
} }

View file

@ -14,11 +14,7 @@ public final class UCommand extends UCommandBase {
@Override @Override
public boolean OnUCommand(CommandSender sender, String alias, String[] args) { public boolean OnUCommand(CommandSender sender, String alias, String[] args) {
if (args.length == 0) return false;
return false; // TODO: Forward call to the correct handler
if (!TBMCCommandBase.GetCommands().containsKey(args[0]))
return false;
TBMCCommandBase cmd = TBMCCommandBase.GetCommands().get(args[0]); //Subcommand
} }
@Override @Override

View file

@ -5,32 +5,21 @@ import java.util.Arrays;
import org.bukkit.command.CommandSender; import org.bukkit.command.CommandSender;
import io.github.norbipeti.thebuttonmcchat.commands.TBMCCommandBase; import io.github.norbipeti.thebuttonmcchat.commands.TBMCCommandBase;
import io.github.norbipeti.thebuttonmcchat.commands.TBMCSubCommandBase;
public abstract class UCommandBase extends TBMCCommandBase { public abstract class UCommandBase extends TBMCCommandBase {
public abstract String[] GetHelpText(String alias); public abstract String[] GetHelpText(String alias);
@Override @Override
public boolean OnCommand(CommandSender sender, String alias, String[] args) { public String GetCommandPath() {
if (args.length == 0) return "u/" + GetUCommandPath();
return false;
return OnUCommand(sender, alias,
Arrays.copyOfRange(args, 1, args.length));
} }
public abstract boolean OnUCommand(CommandSender sender, String alias, public abstract String GetUCommandPath(); // TODO: Help for /u commands
String[] args);
@Override
public String GetCommandName() {
return "u";
}
public abstract String GetUCommandName(); // TODO: Help for /u commands
@Override @Override
public boolean GetPlayerOnly() { public boolean GetPlayerOnly() {
return true; return true;
} }
} }