mirror of
https://github.com/PaperMC/Paper.git
synced 2024-12-02 13:07:06 +01:00
[Bleeding] Added automatically generated plugin-level sub-indexes to the master help index. Addresses BUKKIT-1180
This commit is contained in:
parent
184faf1f29
commit
f87e053c66
2 changed files with 67 additions and 20 deletions
|
@ -1,12 +1,21 @@
|
||||||
package org.bukkit.craftbukkit.help;
|
package org.bukkit.craftbukkit.help;
|
||||||
|
|
||||||
|
import org.bukkit.help.HelpTopic;
|
||||||
|
|
||||||
import java.util.Comparator;
|
import java.util.Comparator;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Used to impose a custom total ordering on help topics. All topics are listed in alphabetic order, but topics
|
* Used to impose a custom total ordering on help topics. All topics are listed in alphabetic order, but topics
|
||||||
* that start with a slash come after topics that don't.
|
* that start with a slash come after topics that don't.
|
||||||
*/
|
*/
|
||||||
public class HelpTopicComparator implements Comparator<String> {
|
public class HelpTopicComparator implements Comparator<HelpTopic> {
|
||||||
|
private TopicNameComparator tnc = new TopicNameComparator();
|
||||||
|
|
||||||
|
public int compare(HelpTopic lhs, HelpTopic rhs) {
|
||||||
|
return tnc.compare(lhs.getName(), rhs.getName());
|
||||||
|
}
|
||||||
|
|
||||||
|
public static class TopicNameComparator implements Comparator<String> {
|
||||||
public int compare(String lhs, String rhs) {
|
public int compare(String lhs, String rhs) {
|
||||||
if (lhs.startsWith("/") && !rhs.startsWith("/")) {
|
if (lhs.startsWith("/") && !rhs.startsWith("/")) {
|
||||||
return 1;
|
return 1;
|
||||||
|
@ -17,3 +26,4 @@ public class HelpTopicComparator implements Comparator<String> {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
|
@ -2,11 +2,9 @@ package org.bukkit.craftbukkit.help;
|
||||||
|
|
||||||
import com.google.common.base.Predicates;
|
import com.google.common.base.Predicates;
|
||||||
import com.google.common.collect.Collections2;
|
import com.google.common.collect.Collections2;
|
||||||
|
import org.bukkit.ChatColor;
|
||||||
import org.bukkit.Server;
|
import org.bukkit.Server;
|
||||||
import org.bukkit.command.Command;
|
import org.bukkit.command.*;
|
||||||
import org.bukkit.command.CommandExecutor;
|
|
||||||
import org.bukkit.command.MultipleCommandAlias;
|
|
||||||
import org.bukkit.command.PluginCommand;
|
|
||||||
import org.bukkit.command.defaults.BukkitCommand;
|
import org.bukkit.command.defaults.BukkitCommand;
|
||||||
import org.bukkit.command.defaults.VanillaCommand;
|
import org.bukkit.command.defaults.VanillaCommand;
|
||||||
import org.bukkit.craftbukkit.CraftServer;
|
import org.bukkit.craftbukkit.CraftServer;
|
||||||
|
@ -21,11 +19,13 @@ public class SimpleHelpMap implements HelpMap {
|
||||||
|
|
||||||
private HelpTopic defaultTopic;
|
private HelpTopic defaultTopic;
|
||||||
private Map<String, HelpTopic> helpTopics;
|
private Map<String, HelpTopic> helpTopics;
|
||||||
|
private Set<HelpTopic> pluginIndexes;
|
||||||
private Map<Class, HelpTopicFactory<Command>> topicFactoryMap;
|
private Map<Class, HelpTopicFactory<Command>> topicFactoryMap;
|
||||||
private CraftServer server;
|
private CraftServer server;
|
||||||
|
|
||||||
public SimpleHelpMap(CraftServer server) {
|
public SimpleHelpMap(CraftServer server) {
|
||||||
helpTopics = new TreeMap<String, HelpTopic>(new HelpTopicComparator()); // Using a TreeMap for its explicit sorting on key
|
helpTopics = new TreeMap<String, HelpTopic>(new HelpTopicComparator.TopicNameComparator()); // Using a TreeMap for its explicit sorting on key
|
||||||
|
pluginIndexes = new TreeSet<HelpTopic>(new HelpTopicComparator());
|
||||||
defaultTopic = new IndexHelpTopic("Index", null, null, Collections2.filter(helpTopics.values(), Predicates.not(Predicates.instanceOf(CommandAliasHelpTopic.class))));
|
defaultTopic = new IndexHelpTopic("Index", null, null, Collections2.filter(helpTopics.values(), Predicates.not(Predicates.instanceOf(CommandAliasHelpTopic.class))));
|
||||||
topicFactoryMap = new HashMap<Class, HelpTopicFactory<Command>>();
|
topicFactoryMap = new HashMap<Class, HelpTopicFactory<Command>>();
|
||||||
this.server = server;
|
this.server = server;
|
||||||
|
@ -45,6 +45,10 @@ public class SimpleHelpMap implements HelpMap {
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public Collection<HelpTopic> getHelpTopics() {
|
||||||
|
return helpTopics.values();
|
||||||
|
}
|
||||||
|
|
||||||
public synchronized void addTopic(HelpTopic topic) {
|
public synchronized void addTopic(HelpTopic topic) {
|
||||||
// Existing topics take priority
|
// Existing topics take priority
|
||||||
if (!helpTopics.containsKey(topic.getName())) {
|
if (!helpTopics.containsKey(topic.getName())) {
|
||||||
|
@ -89,11 +93,13 @@ public class SimpleHelpMap implements HelpMap {
|
||||||
// Register a topic
|
// Register a topic
|
||||||
for (Class c : topicFactoryMap.keySet()) {
|
for (Class c : topicFactoryMap.keySet()) {
|
||||||
if (c.isAssignableFrom(command.getClass())) {
|
if (c.isAssignableFrom(command.getClass())) {
|
||||||
addTopic(topicFactoryMap.get(c).createTopic(command));
|
HelpTopic t = topicFactoryMap.get(c).createTopic(command);
|
||||||
|
if (t != null) addTopic(t);
|
||||||
continue outer;
|
continue outer;
|
||||||
}
|
}
|
||||||
if (command instanceof PluginCommand && c.isAssignableFrom(((PluginCommand)command).getExecutor().getClass())) {
|
if (command instanceof PluginCommand && c.isAssignableFrom(((PluginCommand)command).getExecutor().getClass())) {
|
||||||
addTopic(topicFactoryMap.get(c).createTopic(command));
|
HelpTopic t = topicFactoryMap.get(c).createTopic(command);
|
||||||
|
if (t != null) addTopic(t);
|
||||||
continue outer;
|
continue outer;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -120,6 +126,15 @@ public class SimpleHelpMap implements HelpMap {
|
||||||
// Add alias sub-index
|
// Add alias sub-index
|
||||||
addTopic(new IndexHelpTopic("Aliases", "Lists command aliases", null, Collections2.filter(helpTopics.values(), Predicates.instanceOf(CommandAliasHelpTopic.class))));
|
addTopic(new IndexHelpTopic("Aliases", "Lists command aliases", null, Collections2.filter(helpTopics.values(), Predicates.instanceOf(CommandAliasHelpTopic.class))));
|
||||||
|
|
||||||
|
// Initialize plugin-level sub-topics
|
||||||
|
Map<String, Set<HelpTopic>> pluginIndexes = new HashMap<String, Set<HelpTopic>>();
|
||||||
|
fillPluginIndexes(pluginIndexes, server.getCommandMap().getCommands());
|
||||||
|
fillPluginIndexes(pluginIndexes, server.getCommandMap().getFallbackCommands());
|
||||||
|
|
||||||
|
for (Map.Entry<String, Set<HelpTopic>> entry : pluginIndexes.entrySet()) {
|
||||||
|
addTopic(new IndexHelpTopic(entry.getKey(), "All commands for " + entry.getKey(), null, entry.getValue(), ChatColor.GRAY + "Below is a list of all " + entry.getKey() + " commands:"));
|
||||||
|
}
|
||||||
|
|
||||||
// Amend help topics from the help.yml file
|
// Amend help topics from the help.yml file
|
||||||
for (HelpTopicAmendment amendment : helpYamlReader.getTopicAmendments()) {
|
for (HelpTopicAmendment amendment : helpYamlReader.getTopicAmendments()) {
|
||||||
if (helpTopics.containsKey(amendment.getTopicName())) {
|
if (helpTopics.containsKey(amendment.getTopicName())) {
|
||||||
|
@ -131,14 +146,36 @@ public class SimpleHelpMap implements HelpMap {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private void fillPluginIndexes(Map<String, Set<HelpTopic>> pluginIndexes, Collection<? extends Command> commands) {
|
||||||
|
for (Command command : commands) {
|
||||||
|
String pluginName = getCommandPluginName(command);
|
||||||
|
if (pluginName != null) {
|
||||||
|
HelpTopic topic = getHelpTopic("/" + command.getLabel());
|
||||||
|
if (topic != null) {
|
||||||
|
if (!pluginIndexes.containsKey(pluginName)) {
|
||||||
|
pluginIndexes.put(pluginName, new TreeSet<HelpTopic>(new HelpTopicComparator())); //keep things in topic order
|
||||||
|
}
|
||||||
|
pluginIndexes.get(pluginName).add(topic);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
private String getCommandPluginName(Command command) {
|
||||||
|
if (command instanceof BukkitCommand || command instanceof VanillaCommand) {
|
||||||
|
return "Bukkit";
|
||||||
|
}
|
||||||
|
if (command instanceof PluginIdentifiableCommand) {
|
||||||
|
return ((PluginIdentifiableCommand)command).getPlugin().getName();
|
||||||
|
}
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
|
||||||
private boolean commandInIgnoredPlugin(Command command, List<String> ignoredPlugins) {
|
private boolean commandInIgnoredPlugin(Command command, List<String> ignoredPlugins) {
|
||||||
if (command instanceof BukkitCommand && ignoredPlugins.contains("Bukkit")) {
|
if ((command instanceof BukkitCommand || command instanceof VanillaCommand) && ignoredPlugins.contains("Bukkit")) {
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
if (command instanceof VanillaCommand && ignoredPlugins.contains("Bukkit")) {
|
if (command instanceof PluginIdentifiableCommand && ignoredPlugins.contains(((PluginIdentifiableCommand)command).getPlugin().getName())) {
|
||||||
return true;
|
|
||||||
}
|
|
||||||
if (command instanceof PluginCommand && ignoredPlugins.contains(((PluginCommand)command).getPlugin().getName())) {
|
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
return false;
|
return false;
|
||||||
|
|
Loading…
Reference in a new issue