2024-12-11 22:26:36 +01:00
--- a/com/mojang/brigadier/CommandDispatcher.java
+++ b/com/mojang/brigadier/CommandDispatcher.java
2024-12-13 17:02:13 +01:00
@@ -297,15 +_,21 @@
2024-07-01 20:58:49 +02:00
List<ParseResults<S>> potentials = null;
final int cursor = originalReader.getCursor();
- for (final CommandNode<S> child : node.getRelevantNodes(originalReader)) {
+ for (final CommandNode<S> child : node.getRelevantNodes(originalReader, source)) { // Paper - prioritize mc commands in function parsing
if (!child.canUse(source)) {
continue;
2024-02-05 11:54:04 +01:00
}
final CommandContextBuilder<S> context = contextSoFar.copy();
final StringReader reader = new StringReader(originalReader);
+ boolean stop = false; // Paper - Handle non-recoverable exceptions
try {
try {
child.parse(reader, context);
+ // Paper start - Handle non-recoverable exceptions
+ } catch (final io.papermc.paper.brigadier.TagParseCommandSyntaxException e) {
+ stop = true;
+ throw e;
+ // Paper end - Handle non-recoverable exceptions
} catch (final RuntimeException ex) {
throw CommandSyntaxException.BUILT_IN_EXCEPTIONS.dispatcherParseException().createWithContext(reader, ex.getMessage());
}
2024-12-13 17:02:13 +01:00
@@ -320,6 +_,7 @@
2024-02-05 11:54:04 +01:00
}
errors.put(child, ex);
reader.setCursor(cursor);
+ if (stop) return new ParseResults<>(contextSoFar, originalReader, errors); // Paper - Handle non-recoverable exceptions
continue;
}
2024-12-13 17:02:13 +01:00
@@ -451,7 +_,7 @@
2022-08-02 04:50:34 +02:00
}
private String getSmartUsage(final CommandNode<S> node, final S source, final boolean optional, final boolean deep) {
- if (!node.canUse(source)) {
+ if (source != null && !node.canUse(source)) { // Paper
return null;
}
2024-12-13 17:02:13 +01:00
@@ -465,7 +_,7 @@
final String redirect = node.getRedirect() == root ? "..." : "-> " + node.getRedirect().getUsageText();
return self + ARGUMENT_SEPARATOR + redirect;
2022-08-02 04:50:34 +02:00
} else {
- final Collection<CommandNode<S>> children = node.getChildren().stream().filter(c -> c.canUse(source)).collect(Collectors.toList());
+ final Collection<CommandNode<S>> children = node.getChildren().stream().filter(c -> source == null || c.canUse(source)).collect(Collectors.toList()); // Paper
if (children.size() == 1) {
2024-12-13 17:02:13 +01:00
final String usage = getSmartUsage(children.iterator().next(), source, childOptional, childOptional);
2022-08-02 04:50:34 +02:00
if (usage != null) {
2024-12-13 17:02:13 +01:00
@@ -537,10 +_,14 @@
2021-09-12 00:14:21 +02:00
int i = 0;
2024-12-11 22:26:36 +01:00
for (final CommandNode<S> node : parent.getChildren()) {
CompletableFuture<Suggestions> future = Suggestions.empty();
2021-09-12 00:14:21 +02:00
+ // Paper start - Don't suggest if the requirement isn't met
+ if (parent != this.root || node.canUse(context.getSource())) {
2024-12-11 22:26:36 +01:00
try {
- future = node.listSuggestions(context.build(truncatedInput), new SuggestionsBuilder(truncatedInput, truncatedInputLowerCase, start));
2021-09-12 00:14:21 +02:00
+ future = node.listSuggestions(context.build(truncatedInput), new SuggestionsBuilder(truncatedInput, truncatedInputLowerCase, start)); // CraftBukkit
2024-12-11 22:26:36 +01:00
} catch (final CommandSyntaxException ignored) {
}
2021-09-12 00:14:21 +02:00
+ }
+ // Paper end - Don't suggest if the requirement isn't met
2024-12-11 22:26:36 +01:00
futures[i++] = future;
2021-09-12 00:14:21 +02:00
}