mirror of
https://github.com/PaperMC/Paper.git
synced 2025-01-24 17:22:55 +01:00
Set help index page to 1 for invalid numbers. Fixes BUKKIT-1569
By: feildmaster <admin@feildmaster.com>
This commit is contained in:
parent
8726d93ca1
commit
b475946a3d
1 changed files with 33 additions and 17 deletions
|
@ -37,7 +37,14 @@ public class HelpCommand extends VanillaCommand {
|
||||||
pageNumber = 1;
|
pageNumber = 1;
|
||||||
} else if (NumberUtils.isDigits(args[args.length - 1])) {
|
} else if (NumberUtils.isDigits(args[args.length - 1])) {
|
||||||
command = StringUtils.join(ArrayUtils.subarray(args, 0, args.length - 1), " ");
|
command = StringUtils.join(ArrayUtils.subarray(args, 0, args.length - 1), " ");
|
||||||
pageNumber = NumberUtils.createInteger(args[args.length - 1]);
|
try {
|
||||||
|
pageNumber = NumberUtils.createInteger(args[args.length - 1]);
|
||||||
|
} catch (NumberFormatException exception) {
|
||||||
|
pageNumber = 1;
|
||||||
|
}
|
||||||
|
if (pageNumber <= 0) {
|
||||||
|
pageNumber = 1;
|
||||||
|
}
|
||||||
} else {
|
} else {
|
||||||
command = StringUtils.join(args, " ");
|
command = StringUtils.join(args, " ");
|
||||||
pageNumber = 1;
|
pageNumber = 1;
|
||||||
|
@ -57,7 +64,7 @@ public class HelpCommand extends VanillaCommand {
|
||||||
if (topic == null) {
|
if (topic == null) {
|
||||||
topic = helpMap.getHelpTopic("/" + command);
|
topic = helpMap.getHelpTopic("/" + command);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (topic == null) {
|
if (topic == null) {
|
||||||
topic = findPossibleMatches(command);
|
topic = findPossibleMatches(command);
|
||||||
}
|
}
|
||||||
|
@ -102,46 +109,53 @@ public class HelpCommand extends VanillaCommand {
|
||||||
protected HelpTopic findPossibleMatches(String searchString) {
|
protected HelpTopic findPossibleMatches(String searchString) {
|
||||||
int maxDistance = (searchString.length() / 5) + 3;
|
int maxDistance = (searchString.length() / 5) + 3;
|
||||||
Set<HelpTopic> possibleMatches = new TreeSet<HelpTopic>(HelpTopicComparator.helpTopicComparatorInstance());
|
Set<HelpTopic> possibleMatches = new TreeSet<HelpTopic>(HelpTopicComparator.helpTopicComparatorInstance());
|
||||||
|
|
||||||
if (searchString.startsWith("/")) {
|
if (searchString.startsWith("/")) {
|
||||||
searchString = searchString.substring(1);
|
searchString = searchString.substring(1);
|
||||||
}
|
}
|
||||||
|
|
||||||
for (HelpTopic topic : Bukkit.getServer().getHelpMap().getHelpTopics()) {
|
for (HelpTopic topic : Bukkit.getServer().getHelpMap().getHelpTopics()) {
|
||||||
String trimmedTopic = topic.getName().startsWith("/") ? topic.getName().substring(1) : topic.getName();
|
String trimmedTopic = topic.getName().startsWith("/") ? topic.getName().substring(1) : topic.getName();
|
||||||
|
|
||||||
if (trimmedTopic.length() < searchString.length()) {
|
if (trimmedTopic.length() < searchString.length()) {
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (Character.toLowerCase(trimmedTopic.charAt(0)) != Character.toLowerCase(searchString.charAt(0))) {
|
if (Character.toLowerCase(trimmedTopic.charAt(0)) != Character.toLowerCase(searchString.charAt(0))) {
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (damerauLevenshteinDistance(searchString, trimmedTopic.substring(0, searchString.length())) < maxDistance) {
|
if (damerauLevenshteinDistance(searchString, trimmedTopic.substring(0, searchString.length())) < maxDistance) {
|
||||||
possibleMatches.add(topic);
|
possibleMatches.add(topic);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if (possibleMatches.size() > 0) {
|
if (possibleMatches.size() > 0) {
|
||||||
return new IndexHelpTopic("Search", null, null, possibleMatches, "Search for: " + searchString);
|
return new IndexHelpTopic("Search", null, null, possibleMatches, "Search for: " + searchString);
|
||||||
} else {
|
} else {
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Computes the Dameraur-Levenshtein Distance between two strings. Adapted from the algorithm at
|
* Computes the Dameraur-Levenshtein Distance between two strings. Adapted
|
||||||
* http://en.wikipedia.org/wiki/Damerau–Levenshtein_distance
|
* from the algorithm at <a href="http://en.wikipedia.org/wiki/Damerau–Levenshtein_distance">Wikipedia: Damerau–Levenshtein distance</a>
|
||||||
*
|
*
|
||||||
* @param s1 The first string being compared.
|
* @param s1 The first string being compared.
|
||||||
* @param s2 The second string being compared.
|
* @param s2 The second string being compared.
|
||||||
* @return The number of substitutions, deletions, insertions, and transpositions required to get from s1 to s2.
|
* @return The number of substitutions, deletions, insertions, and
|
||||||
|
* transpositions required to get from s1 to s2.
|
||||||
*/
|
*/
|
||||||
protected static int damerauLevenshteinDistance(String s1, String s2) {
|
protected static int damerauLevenshteinDistance(String s1, String s2) {
|
||||||
if (s1 == null && s2 == null) return 0;
|
if (s1 == null && s2 == null) {
|
||||||
if (s1 != null && s2 == null) return s1.length();
|
return 0;
|
||||||
if (s1 == null && s2 != null) return s2.length();
|
}
|
||||||
|
if (s1 != null && s2 == null) {
|
||||||
|
return s1.length();
|
||||||
|
}
|
||||||
|
if (s1 == null && s2 != null) {
|
||||||
|
return s2.length();
|
||||||
|
}
|
||||||
|
|
||||||
int s1Len = s1.length();
|
int s1Len = s1.length();
|
||||||
int s2Len = s2.length();
|
int s2Len = s2.length();
|
||||||
|
@ -160,7 +174,9 @@ public class HelpCommand extends VanillaCommand {
|
||||||
|
|
||||||
Map<Character, Integer> sd = new HashMap<Character, Integer>();
|
Map<Character, Integer> sd = new HashMap<Character, Integer>();
|
||||||
for (char Letter : (s1 + s2).toCharArray()) {
|
for (char Letter : (s1 + s2).toCharArray()) {
|
||||||
if (!sd.containsKey(Letter)) sd.put(Letter, 0);
|
if (!sd.containsKey(Letter)) {
|
||||||
|
sd.put(Letter, 0);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
for (int i = 1; i <= s1Len; i++) {
|
for (int i = 1; i <= s1Len; i++) {
|
||||||
|
|
Loading…
Add table
Reference in a new issue