aboutsummaryrefslogtreecommitdiff
path: root/spark-bukkit/src/main/java/me/lucko
diff options
context:
space:
mode:
Diffstat (limited to 'spark-bukkit/src/main/java/me/lucko')
-rw-r--r--spark-bukkit/src/main/java/me/lucko/spark/bukkit/CommandMapUtil.java39
1 files changed, 18 insertions, 21 deletions
diff --git a/spark-bukkit/src/main/java/me/lucko/spark/bukkit/CommandMapUtil.java b/spark-bukkit/src/main/java/me/lucko/spark/bukkit/CommandMapUtil.java
index 058ef55..8d3c125 100644
--- a/spark-bukkit/src/main/java/me/lucko/spark/bukkit/CommandMapUtil.java
+++ b/spark-bukkit/src/main/java/me/lucko/spark/bukkit/CommandMapUtil.java
@@ -73,9 +73,9 @@ enum CommandMapUtil {
}
@SuppressWarnings("unchecked")
- private static Map<String, Command> getKnownCommandMap() {
+ private static Map<String, Command> getKnownCommandMap(CommandMap commandMap) {
try {
- return (Map<String, Command>) KNOWN_COMMANDS_FIELD.get(getCommandMap());
+ return (Map<String, Command>) KNOWN_COMMANDS_FIELD.get(commandMap);
} catch (Exception e) {
throw new RuntimeException("Could not get known commands map", e);
}
@@ -90,19 +90,21 @@ enum CommandMapUtil {
*/
public static void registerCommand(Plugin plugin, CommandExecutor command, String... aliases) {
Preconditions.checkArgument(aliases.length != 0, "No aliases");
+ CommandMap commandMap = getCommandMap();
+ Map<String, Command> knownCommandMap = getKnownCommandMap(commandMap);
+
for (String alias : aliases) {
try {
PluginCommand cmd = COMMAND_CONSTRUCTOR.newInstance(alias, plugin);
- getCommandMap().register(plugin.getDescription().getName(), cmd);
-
- Map<String, Command> knownCommandMap = getKnownCommandMap();
+ commandMap.register(plugin.getDescription().getName(), cmd);
knownCommandMap.put(plugin.getDescription().getName().toLowerCase() + ":" + alias.toLowerCase(), cmd);
knownCommandMap.put(alias.toLowerCase(), cmd);
cmd.setLabel(alias.toLowerCase());
cmd.setExecutor(command);
+
if (command instanceof TabCompleter) {
cmd.setTabCompleter((TabCompleter) command);
}
@@ -118,24 +120,19 @@ enum CommandMapUtil {
* @param command the command instance
*/
public static void unregisterCommand(CommandExecutor command) {
- CommandMap map = getCommandMap();
- try {
- //noinspection unchecked
- Map<String, Command> knownCommands = (Map<String, Command>) KNOWN_COMMANDS_FIELD.get(map);
-
- Iterator<Command> iterator = knownCommands.values().iterator();
- while (iterator.hasNext()) {
- Command cmd = iterator.next();
- if (cmd instanceof PluginCommand) {
- CommandExecutor executor = ((PluginCommand) cmd).getExecutor();
- if (command == executor) {
- cmd.unregister(map);
- iterator.remove();
- }
+ CommandMap commandMap = getCommandMap();
+ Map<String, Command> knownCommandMap = getKnownCommandMap(commandMap);
+
+ Iterator<Command> iterator = knownCommandMap.values().iterator();
+ while (iterator.hasNext()) {
+ Command cmd = iterator.next();
+ if (cmd instanceof PluginCommand) {
+ CommandExecutor executor = ((PluginCommand) cmd).getExecutor();
+ if (command == executor) {
+ cmd.unregister(commandMap);
+ iterator.remove();
}
}
- } catch (Exception e) {
- throw new RuntimeException("Could not unregister command", e);
}
}