summaryrefslogtreecommitdiffstats
path: root/src/main/java/org
diff options
context:
space:
mode:
authorVictorD <victor.danell@gmail.com>2011-01-18 01:13:45 +0100
committerVictorD <victor.danell@gmail.com>2011-01-18 01:13:45 +0100
commit8088a329cd53228bd7f82bc6c03bc0c88be4a3d3 (patch)
treedf6bd8bc68ad7404e7ee0fe3eab58cbbafff6597 /src/main/java/org
parent73d6070d889d0325072d9ed7a225e73f68bffb4a (diff)
downloadcraftbukkit-8088a329cd53228bd7f82bc6c03bc0c88be4a3d3.tar
craftbukkit-8088a329cd53228bd7f82bc6c03bc0c88be4a3d3.tar.gz
craftbukkit-8088a329cd53228bd7f82bc6c03bc0c88be4a3d3.tar.lz
craftbukkit-8088a329cd53228bd7f82bc6c03bc0c88be4a3d3.tar.xz
craftbukkit-8088a329cd53228bd7f82bc6c03bc0c88be4a3d3.zip
Updated plugin commands to allow for aliases and fallback on name collision.
Diffstat (limited to 'src/main/java/org')
-rw-r--r--src/main/java/org/bukkit/craftbukkit/CraftServer.java29
1 files changed, 17 insertions, 12 deletions
diff --git a/src/main/java/org/bukkit/craftbukkit/CraftServer.java b/src/main/java/org/bukkit/craftbukkit/CraftServer.java
index f53d0866..a1bca4a9 100644
--- a/src/main/java/org/bukkit/craftbukkit/CraftServer.java
+++ b/src/main/java/org/bukkit/craftbukkit/CraftServer.java
@@ -1,5 +1,9 @@
package org.bukkit.craftbukkit;
+import org.bukkit.command.Command;
+import org.bukkit.command.CommandMap;
+import org.bukkit.command.SimpleCommandMap;
+import org.bukkit.command.PluginCommandYamlParser;
import org.bukkit.entity.Player;
import java.io.File;
import java.util.ArrayList;
@@ -10,10 +14,8 @@ import net.minecraft.server.EntityPlayerMP;
import net.minecraft.server.MinecraftServer;
import net.minecraft.server.ServerConfigurationManager;
import org.bukkit.*;
-import org.bukkit.plugin.CommandManager;
import org.bukkit.plugin.Plugin;
import org.bukkit.plugin.PluginManager;
-import org.bukkit.plugin.SimpleCommandManager;
import org.bukkit.plugin.SimplePluginManager;
import org.bukkit.plugin.java.JavaPluginLoader;
@@ -22,7 +24,7 @@ public final class CraftServer implements Server
private final String serverName = "Craftbukkit";
private final String serverVersion = "1.2_01";
private final PluginManager pluginManager = new SimplePluginManager(this);
- private final CommandManager commandManager = new SimpleCommandManager();
+ private final CommandMap commandMap = new SimpleCommandMap();
protected final MinecraftServer console;
protected final ServerConfigurationManager server;
@@ -34,18 +36,13 @@ public final class CraftServer implements Server
}
public void loadPlugins() {
- File pluginFolder = (File) console.options.valueOf("plugins");
+ File pluginFolder = (File)console.options.valueOf("plugins");
if (pluginFolder.exists()) {
try {
Plugin[] plugins = pluginManager.loadPlugins(pluginFolder);
-
for (Plugin plugin : plugins) {
- if (commandManager.registerCommands(plugin)) {
- pluginManager.enablePlugin(plugin);
- } else {
- Logger.getLogger(CraftServer.class.getName()).log(Level.SEVERE, "Plugin " + plugin.getDescription().getName() + " failed to load. Reason: Requested commands already in use.");
- }
+ loadPlugin(plugin);
}
} catch (Throwable ex) {
Logger.getLogger(CraftServer.class.getName()).log(Level.SEVERE, ex.getMessage() + " (Is it up to date?)", ex);
@@ -55,6 +52,14 @@ public final class CraftServer implements Server
}
}
+ private void loadPlugin(Plugin plugin) {
+ List<Command> pluginCommands = PluginCommandYamlParser.parse(plugin);
+ if (!pluginCommands.isEmpty()) {
+ commandMap.registerAll(plugin.getDescription().getName(), pluginCommands);
+ }
+ pluginManager.enablePlugin(plugin);
+ }
+
public String getName() {
return serverName;
}
@@ -148,7 +153,7 @@ public final class CraftServer implements Server
return server;
}
- public boolean dispatchCommand(Player player, String cmd) {
- return commandManager.dispatchCommand(player, cmd);
+ public boolean dispatchCommand(Player player, String commandLine) {
+ return commandMap.dispatch(player, commandLine);
}
}