Added the ability to unload using the fallback.*
* Unfortunately it still won't remove the commands from the TabComplete * Also, changed the error msg from an unregistered command to help lessen the confusion on the previous issue.
This commit is contained in:
@@ -11,6 +11,7 @@ import java.lang.reflect.Method;
|
||||
import java.lang.reflect.Modifier;
|
||||
import java.util.ArrayList;
|
||||
import java.util.HashMap;
|
||||
import java.util.List;
|
||||
import java.util.Map;
|
||||
import java.util.logging.Level;
|
||||
|
||||
@@ -154,6 +155,7 @@ public class CommandManager {
|
||||
}
|
||||
reader.close();
|
||||
} catch (Exception e) {
|
||||
e.printStackTrace();
|
||||
plugin.getLogger().log(Level.WARNING, "Error while loading command file. (" + sourceFile.getAbsolutePath() + ")");
|
||||
plugin.getLogger().log(Level.WARNING, e.getCause().toString());
|
||||
errors = true;
|
||||
@@ -325,6 +327,41 @@ public class CommandManager {
|
||||
}
|
||||
}
|
||||
|
||||
public static void unregisterAllWithFallback(String fallback) {
|
||||
try {
|
||||
final Field cmdMap = Bukkit.getServer().getClass().getDeclaredField("commandMap");
|
||||
cmdMap.setAccessible(true);
|
||||
CommandMap map = (CommandMap) cmdMap.get(Bukkit.getServer());
|
||||
final Field knownCommandsField = map.getClass().getSuperclass().getDeclaredField("knownCommands");
|
||||
knownCommandsField.setAccessible(true);
|
||||
@SuppressWarnings("unchecked")
|
||||
Map<String, org.bukkit.command.Command> knownCommands = (Map<String, org.bukkit.command.Command>) knownCommandsField.get(map);
|
||||
|
||||
fallback = fallback.toLowerCase();
|
||||
System.out.println(fallback);
|
||||
|
||||
List<String> toRemove = new ArrayList<>();
|
||||
|
||||
for (String key: knownCommands.keySet()) {
|
||||
org.bukkit.command.Command value = knownCommands.get(key);
|
||||
if ((value instanceof Executable) && ((Executable)value).getMethodContainerName().equals(fallback)) {
|
||||
toRemove.add(key);
|
||||
value.unregister(map);
|
||||
}
|
||||
}
|
||||
for (String key : toRemove) {
|
||||
//EmptyCommand emptyCommand = new EmptyCommand(key);
|
||||
knownCommands.remove(key);
|
||||
//map.register(key, emptyCommand);
|
||||
System.out.println("Unregestered " + key);
|
||||
}
|
||||
|
||||
|
||||
} catch (Exception e) {
|
||||
e.printStackTrace();
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* Parses the source code into an abstract command syntax
|
||||
*
|
||||
@@ -719,7 +756,7 @@ public class CommandManager {
|
||||
components.help = null;
|
||||
components.permission = null;
|
||||
components.type = null;
|
||||
Executable cmd = new Executable(cmdName, constructHelpPages(cmdName, components));
|
||||
Executable cmd = new Executable(cmdName, constructHelpPages(cmdName, components), methodContainer.getClass().getSimpleName());
|
||||
cmd.register(methods, plugin, methodContainer, components.getAliases());
|
||||
}
|
||||
|
||||
|
||||
@@ -8,13 +8,13 @@ public class EmptyCommand extends Executable
|
||||
{
|
||||
public EmptyCommand(String name)
|
||||
{
|
||||
super(name, null);
|
||||
super(name, null, "");
|
||||
}
|
||||
|
||||
@Override
|
||||
public boolean execute(CommandSender sender, String name, String[] args_)
|
||||
{
|
||||
sender.sendMessage("§cUnknown command. Use §e/help§c, §e/plugins§c or ask a mod.");
|
||||
sender.sendMessage("§cCommand no longer Exists. Use §e/help§c, §e/plugins§c or ask a mod.");
|
||||
return true;
|
||||
}
|
||||
}
|
||||
|
||||
@@ -35,17 +35,23 @@ public class Executable extends org.bukkit.command.Command {
|
||||
private ArrayList<ExecutableDefinition> commands;
|
||||
private ArrayList<HelpPageCommand[]> help;
|
||||
private String name;
|
||||
private String methodContainerName;
|
||||
private JavaPlugin plugin;
|
||||
|
||||
public Executable(String name, ArrayList<HelpPageCommand[]> help) {
|
||||
public Executable(String name, ArrayList<HelpPageCommand[]> help, String methodContainerName) {
|
||||
super(name);
|
||||
this.help = help;
|
||||
this.name = name;
|
||||
this.commands = new ArrayList<ExecutableDefinition>();
|
||||
this.methodContainerName = methodContainerName;
|
||||
}
|
||||
|
||||
public String getMethodContainerName() {
|
||||
return methodContainerName;
|
||||
}
|
||||
|
||||
public void register(ArrayList<Method> methods, JavaPlugin plugin, Object methodContainer, ArrayList<String> aliases) {
|
||||
String moduleName = methodContainer.getClass().getSimpleName();
|
||||
methodContainerName = methodContainer.getClass().getSimpleName().toLowerCase();
|
||||
for (HelpPageCommand[] page : help) {
|
||||
for (HelpPageCommand cmd : page) {
|
||||
if (cmd != null) {
|
||||
@@ -95,13 +101,13 @@ public class Executable extends org.bukkit.command.Command {
|
||||
@SuppressWarnings("unchecked")
|
||||
Map<String, Command> knownCommands = (Map<String, Command>) knownCommandsField.get(map);
|
||||
knownCommands.remove(name);
|
||||
map.register(moduleName, this);
|
||||
map.register(methodContainerName, this);
|
||||
for (String alias : aliases) {
|
||||
Executable cmd = new Executable(alias, this.help);
|
||||
Executable cmd = new Executable(alias, this.help, methodContainerName);
|
||||
cmd.commands = this.commands;
|
||||
cmd.plugin = this.plugin;
|
||||
knownCommands.remove(alias);
|
||||
map.register(moduleName, cmd);
|
||||
map.register(methodContainerName, cmd);
|
||||
}
|
||||
} catch (Exception e) {
|
||||
plugin.getLogger().log(Level.SEVERE, "Failed to register command '" + name + "'!");
|
||||
|
||||
Reference in New Issue
Block a user