mirror of
https://github.com/PaperMC/Paper.git
synced 2025-01-09 19:49:35 +01:00
[Bleeding] Added support for linking custom CommandExecutor types to a HelpTopicFactory. Fixes BUKKIT-1027
By: rmichela <deltahat@gmail.com>
This commit is contained in:
parent
a9a9110af2
commit
6f7d9537f3
1 changed files with 15 additions and 7 deletions
|
@ -1,7 +1,9 @@
|
||||||
package org.bukkit.craftbukkit.help;
|
package org.bukkit.craftbukkit.help;
|
||||||
|
|
||||||
import org.bukkit.command.Command;
|
import org.bukkit.command.Command;
|
||||||
|
import org.bukkit.command.CommandExecutor;
|
||||||
import org.bukkit.command.MultipleCommandAlias;
|
import org.bukkit.command.MultipleCommandAlias;
|
||||||
|
import org.bukkit.command.PluginCommand;
|
||||||
import org.bukkit.command.defaults.VanillaCommand;
|
import org.bukkit.command.defaults.VanillaCommand;
|
||||||
import org.bukkit.craftbukkit.CraftServer;
|
import org.bukkit.craftbukkit.CraftServer;
|
||||||
import org.bukkit.help.HelpMap;
|
import org.bukkit.help.HelpMap;
|
||||||
|
@ -71,12 +73,18 @@ public class SimpleHelpMap implements HelpMap {
|
||||||
// ** Load topics from highest to lowest priority order **
|
// ** Load topics from highest to lowest priority order **
|
||||||
|
|
||||||
// Initialize help topics from the server's command map
|
// Initialize help topics from the server's command map
|
||||||
for (Command command : server.getCommandMap().getCommands()) {
|
outer: for (Command command : server.getCommandMap().getCommands()) {
|
||||||
if (topicFactoryMap.containsKey(command.getClass())) {
|
for (Class c : topicFactoryMap.keySet()) {
|
||||||
addTopic(topicFactoryMap.get(command.getClass()).createTopic(command));
|
if (c.isAssignableFrom(command.getClass())) {
|
||||||
} else {
|
addTopic(topicFactoryMap.get(c).createTopic(command));
|
||||||
addTopic(new GenericCommandHelpTopic(command));
|
continue outer;
|
||||||
|
}
|
||||||
|
if (command instanceof PluginCommand && c.isAssignableFrom(((PluginCommand)command).getExecutor().getClass())) {
|
||||||
|
addTopic(topicFactoryMap.get(c).createTopic(command));
|
||||||
|
continue outer;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
addTopic(new GenericCommandHelpTopic(command));
|
||||||
}
|
}
|
||||||
|
|
||||||
// Initialize help topics from the server's fallback commands
|
// Initialize help topics from the server's fallback commands
|
||||||
|
@ -94,8 +102,8 @@ public class SimpleHelpMap implements HelpMap {
|
||||||
}
|
}
|
||||||
|
|
||||||
public void registerHelpTopicFactory(Class commandClass, HelpTopicFactory factory) {
|
public void registerHelpTopicFactory(Class commandClass, HelpTopicFactory factory) {
|
||||||
if (!Command.class.isAssignableFrom(commandClass)) {
|
if (!Command.class.isAssignableFrom(commandClass) && !CommandExecutor.class.isAssignableFrom(commandClass)) {
|
||||||
throw new IllegalArgumentException("commandClass must implement Command");
|
throw new IllegalArgumentException("commandClass must implement either Command or CommandExecutor!");
|
||||||
}
|
}
|
||||||
topicFactoryMap.put(commandClass, factory);
|
topicFactoryMap.put(commandClass, factory);
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue