mirror of
https://github.com/EngineHub/WorldEdit.git
synced 2025-01-24 12:44:56 +08:00
Added more flexibility to the Bukkit dynamic command registration system.
This commit is contained in:
parent
76f1ea9cf2
commit
4fb44ebc1d
@ -27,6 +27,7 @@
|
|||||||
import com.sk89q.minecraft.util.commands.Command;
|
import com.sk89q.minecraft.util.commands.Command;
|
||||||
import com.sk89q.util.ReflectionUtil;
|
import com.sk89q.util.ReflectionUtil;
|
||||||
import org.bukkit.Bukkit;
|
import org.bukkit.Bukkit;
|
||||||
|
import org.bukkit.command.CommandExecutor;
|
||||||
import org.bukkit.command.CommandMap;
|
import org.bukkit.command.CommandMap;
|
||||||
import org.bukkit.command.SimpleCommandMap;
|
import org.bukkit.command.SimpleCommandMap;
|
||||||
import org.bukkit.event.Event;
|
import org.bukkit.event.Event;
|
||||||
@ -37,10 +38,16 @@
|
|||||||
*/
|
*/
|
||||||
public class CommandRegistration {
|
public class CommandRegistration {
|
||||||
private final Plugin plugin;
|
private final Plugin plugin;
|
||||||
|
private final CommandExecutor executor;
|
||||||
private CommandMap fallbackCommands;
|
private CommandMap fallbackCommands;
|
||||||
|
|
||||||
public CommandRegistration(Plugin plugin) {
|
public CommandRegistration(Plugin plugin) {
|
||||||
|
this(plugin, plugin);
|
||||||
|
}
|
||||||
|
|
||||||
|
public CommandRegistration(Plugin plugin, CommandExecutor executor) {
|
||||||
this.plugin = plugin;
|
this.plugin = plugin;
|
||||||
|
this.executor = executor;
|
||||||
}
|
}
|
||||||
|
|
||||||
public boolean registerAll(List<Command> registered) {
|
public boolean registerAll(List<Command> registered) {
|
||||||
@ -49,12 +56,13 @@ public boolean registerAll(List<Command> registered) {
|
|||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
for (Command command : registered) {
|
for (Command command : registered) {
|
||||||
commandMap.register(plugin.getDescription().getName(), new DynamicPluginCommand(command, plugin));
|
commandMap.register(plugin.getDescription().getName(),
|
||||||
|
new DynamicPluginCommand(command.aliases(), command.desc(), command.usage(), executor));
|
||||||
}
|
}
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
private CommandMap getCommandMap() {
|
public CommandMap getCommandMap() {
|
||||||
CommandMap commandMap = ReflectionUtil.getField(plugin.getServer().getPluginManager(), "commandMap");
|
CommandMap commandMap = ReflectionUtil.getField(plugin.getServer().getPluginManager(), "commandMap");
|
||||||
if (commandMap == null) {
|
if (commandMap == null) {
|
||||||
if (fallbackCommands != null) {
|
if (fallbackCommands != null) {
|
||||||
@ -80,7 +88,7 @@ public boolean unregisterCommands() {
|
|||||||
}
|
}
|
||||||
for (Iterator<org.bukkit.command.Command> i = knownCommands.values().iterator(); i.hasNext();) {
|
for (Iterator<org.bukkit.command.Command> i = knownCommands.values().iterator(); i.hasNext();) {
|
||||||
org.bukkit.command.Command cmd = i.next();
|
org.bukkit.command.Command cmd = i.next();
|
||||||
if (cmd instanceof DynamicPluginCommand && ((DynamicPluginCommand) cmd).getPlugin().equals(plugin)) {
|
if (cmd instanceof DynamicPluginCommand && ((DynamicPluginCommand) cmd).getOwner().equals(plugin)) {
|
||||||
i.remove();
|
i.remove();
|
||||||
for (String alias : cmd.getAliases()) {
|
for (String alias : cmd.getAliases()) {
|
||||||
org.bukkit.command.Command aliasCmd = knownCommands.get(alias);
|
org.bukkit.command.Command aliasCmd = knownCommands.get(alias);
|
||||||
|
@ -20,6 +20,7 @@
|
|||||||
|
|
||||||
import com.sk89q.minecraft.util.commands.Command;
|
import com.sk89q.minecraft.util.commands.Command;
|
||||||
import com.sk89q.minecraft.util.commands.CommandsManager;
|
import com.sk89q.minecraft.util.commands.CommandsManager;
|
||||||
|
import org.bukkit.command.CommandExecutor;
|
||||||
import org.bukkit.plugin.Plugin;
|
import org.bukkit.plugin.Plugin;
|
||||||
|
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
@ -35,6 +36,11 @@ public CommandsManagerRegistration(Plugin plugin, CommandsManager<?> commands) {
|
|||||||
this.commands = commands;
|
this.commands = commands;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public CommandsManagerRegistration(Plugin plugin, CommandExecutor executor, CommandsManager<?> commands) {
|
||||||
|
super(plugin, executor);
|
||||||
|
this.commands = commands;
|
||||||
|
}
|
||||||
|
|
||||||
public boolean register(Class<?> clazz) {
|
public boolean register(Class<?> clazz) {
|
||||||
List<Command> registered = commands.registerAndReturn(clazz);
|
List<Command> registered = commands.registerAndReturn(clazz);
|
||||||
return registerAll(registered);
|
return registerAll(registered);
|
||||||
|
@ -19,6 +19,7 @@
|
|||||||
package com.sk89q.bukkit.util;
|
package com.sk89q.bukkit.util;
|
||||||
|
|
||||||
import com.sk89q.minecraft.util.commands.Command;
|
import com.sk89q.minecraft.util.commands.Command;
|
||||||
|
import org.bukkit.command.CommandExecutor;
|
||||||
import org.bukkit.command.CommandSender;
|
import org.bukkit.command.CommandSender;
|
||||||
import org.bukkit.plugin.Plugin;
|
import org.bukkit.plugin.Plugin;
|
||||||
|
|
||||||
@ -29,19 +30,19 @@
|
|||||||
*/
|
*/
|
||||||
public class DynamicPluginCommand extends org.bukkit.command.Command {
|
public class DynamicPluginCommand extends org.bukkit.command.Command {
|
||||||
|
|
||||||
protected final Plugin plugin;
|
protected final CommandExecutor owner;
|
||||||
|
|
||||||
public DynamicPluginCommand(Command command, Plugin plugin) {
|
public DynamicPluginCommand(String[] aliases, String desc, String usage, CommandExecutor owner) {
|
||||||
super(command.aliases()[0], command.desc(), command.usage(), Arrays.asList(command.aliases()));
|
super(aliases[0], desc, usage, Arrays.asList(aliases));
|
||||||
this.plugin = plugin;
|
this.owner = owner;
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public boolean execute(CommandSender sender, String label, String[] args) {
|
public boolean execute(CommandSender sender, String label, String[] args) {
|
||||||
return plugin.onCommand(sender, this, label, args);
|
return owner.onCommand(sender, this, label, args);
|
||||||
}
|
}
|
||||||
|
|
||||||
public Plugin getPlugin() {
|
public Object getOwner() {
|
||||||
return plugin;
|
return owner;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -20,8 +20,10 @@
|
|||||||
|
|
||||||
import java.lang.reflect.Constructor;
|
import java.lang.reflect.Constructor;
|
||||||
import java.lang.reflect.InvocationTargetException;
|
import java.lang.reflect.InvocationTargetException;
|
||||||
|
import java.util.logging.Logger;
|
||||||
|
|
||||||
public class SimpleInjector implements Injector {
|
public class SimpleInjector implements Injector {
|
||||||
|
private static final Logger logger = Logger.getLogger(SimpleInjector.class.getCanonicalName());
|
||||||
private Object[] args;
|
private Object[] args;
|
||||||
private Class<?>[] argClasses;
|
private Class<?>[] argClasses;
|
||||||
|
|
||||||
@ -36,14 +38,23 @@ public SimpleInjector(Object... args) {
|
|||||||
public Object getInstance(Class<?> clazz) {
|
public Object getInstance(Class<?> clazz) {
|
||||||
try {
|
try {
|
||||||
Constructor<?> ctr = clazz.getConstructor(argClasses);
|
Constructor<?> ctr = clazz.getConstructor(argClasses);
|
||||||
|
ctr.setAccessible(true);
|
||||||
return ctr.newInstance(args);
|
return ctr.newInstance(args);
|
||||||
} catch (NoSuchMethodException e) {
|
} catch (NoSuchMethodException e) {
|
||||||
|
logger.severe("Error initializing commands class " + clazz + ": ");
|
||||||
|
e.printStackTrace();
|
||||||
return null;
|
return null;
|
||||||
} catch (InvocationTargetException e) {
|
} catch (InvocationTargetException e) {
|
||||||
|
logger.severe("Error initializing commands class " + clazz + ": ");
|
||||||
|
e.printStackTrace();
|
||||||
return null;
|
return null;
|
||||||
} catch (InstantiationException e) {
|
} catch (InstantiationException e) {
|
||||||
|
logger.severe("Error initializing commands class " + clazz + ": ");
|
||||||
|
e.printStackTrace();
|
||||||
return null;
|
return null;
|
||||||
} catch (IllegalAccessException e) {
|
} catch (IllegalAccessException e) {
|
||||||
|
logger.severe("Error initializing commands class " + clazz + ": ");
|
||||||
|
e.printStackTrace();
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user