Mirror von
https://github.com/PaperMC/Paper.git
synchronisiert 2024-11-16 21:10:17 +01:00
[Bleeding] Fixed a StackOverflowError with command alias handling for Help. Addresses BUKKIT-1253
Dieser Commit ist enthalten in:
Ursprung
8aee4c3f56
Commit
31b1bc02ca
@ -1,5 +1,6 @@
|
||||
package org.bukkit.craftbukkit.help;
|
||||
|
||||
import org.apache.commons.lang.Validate;
|
||||
import org.bukkit.ChatColor;
|
||||
import org.bukkit.command.CommandSender;
|
||||
import org.bukkit.help.HelpMap;
|
||||
@ -14,6 +15,7 @@ public class CommandAliasHelpTopic extends HelpTopic {
|
||||
this.aliasFor = aliasFor.startsWith("/") ? aliasFor : "/" + aliasFor;
|
||||
this.helpMap = helpMap;
|
||||
this.name = alias.startsWith("/") ? alias : "/" + alias;
|
||||
Validate.isTrue(!this.name.equals(this.aliasFor), "Command " + this.name + " cannot be alias for itself");
|
||||
this.shortText = ChatColor.YELLOW + "Alias for " + ChatColor.WHITE + this.aliasFor;
|
||||
}
|
||||
|
||||
|
@ -16,10 +16,10 @@ import java.util.*;
|
||||
* Standard implementation of {@link HelpMap} for CraftBukkit servers.
|
||||
*/
|
||||
public class SimpleHelpMap implements HelpMap {
|
||||
|
||||
|
||||
private final HelpTopic defaultTopic;
|
||||
private final Map<String, HelpTopic> helpTopics;
|
||||
private final Set<HelpTopic> pluginIndexes;
|
||||
private final Set<HelpTopic> pluginIndexes;
|
||||
private final Map<Class, HelpTopicFactory<Command>> topicFactoryMap;
|
||||
private final CraftServer server;
|
||||
private HelpYamlReader yaml;
|
||||
@ -40,7 +40,7 @@ public class SimpleHelpMap implements HelpMap {
|
||||
|
||||
registerHelpTopicFactory(MultipleCommandAlias.class, new MultipleCommandAliasHelpTopicFactory());
|
||||
}
|
||||
|
||||
|
||||
public synchronized HelpTopic getHelpTopic(String topicName) {
|
||||
if (topicName.equals("")) {
|
||||
return defaultTopic;
|
||||
@ -112,14 +112,16 @@ public class SimpleHelpMap implements HelpMap {
|
||||
}
|
||||
addTopic(new GenericCommandHelpTopic(command));
|
||||
}
|
||||
|
||||
|
||||
// Initialize command alias help topics
|
||||
for (Command command : server.getCommandMap().getCommands()) {
|
||||
if (commandInIgnoredPlugin(command, ignoredPlugins)) {
|
||||
continue;
|
||||
}
|
||||
for (String alias : command.getAliases()) {
|
||||
addTopic(new CommandAliasHelpTopic(alias, command.getLabel(), this));
|
||||
if (!helpTopics.containsKey("/" + alias)) {
|
||||
addTopic(new CommandAliasHelpTopic("/" + alias, "/" + command.getLabel(), this));
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
@ -132,7 +134,7 @@ public class SimpleHelpMap implements HelpMap {
|
||||
|
||||
// Add alias sub-index
|
||||
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());
|
||||
@ -152,7 +154,7 @@ 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);
|
||||
@ -167,7 +169,7 @@ public class SimpleHelpMap implements HelpMap {
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
private String getCommandPluginName(Command command) {
|
||||
if (command instanceof BukkitCommand || command instanceof VanillaCommand) {
|
||||
return "Bukkit";
|
||||
@ -177,7 +179,7 @@ public class SimpleHelpMap implements HelpMap {
|
||||
}
|
||||
return null;
|
||||
}
|
||||
|
||||
|
||||
private boolean commandInIgnoredPlugin(Command command, Set<String> ignoredPlugins) {
|
||||
if ((command instanceof BukkitCommand || command instanceof VanillaCommand) && ignoredPlugins.contains("Bukkit")) {
|
||||
return true;
|
||||
|
Laden…
In neuem Issue referenzieren
Einen Benutzer sperren