From bd840a868fe9da9b931b7606e96177b0122a5595 Mon Sep 17 00:00:00 2001 From: themode Date: Sat, 20 Feb 2021 13:10:12 +0100 Subject: [PATCH] Improve optional argument support & client-side brigadier suggestion --- .../server/command/CommandManager.java | 32 ++----------------- 1 file changed, 3 insertions(+), 29 deletions(-) diff --git a/src/main/java/net/minestom/server/command/CommandManager.java b/src/main/java/net/minestom/server/command/CommandManager.java index 34de701c1..ab46f8cc4 100644 --- a/src/main/java/net/minestom/server/command/CommandManager.java +++ b/src/main/java/net/minestom/server/command/CommandManager.java @@ -22,6 +22,7 @@ import java.io.BufferedReader; import java.io.IOException; import java.io.InputStreamReader; import java.util.*; +import java.util.stream.Collectors; /** * Manager used to register {@link Command} and {@link CommandProcessor}. @@ -431,11 +432,8 @@ public final class CommandManager { final int literalNodeId = addCommandNameNode(literalNode, rootChildren, nodes); - // Contains the arguments of the already-parsed syntaxes - List[]> syntaxesArguments = new ArrayList<>(); - // Contains the nodes of an argument - Map, List> storedArgumentsNodes = new HashMap<>(); - + // Sort syntaxes by argument count. Brigadier requires it. + syntaxes = syntaxes.stream().sorted(Comparator.comparingInt(o -> -o.getArguments().length)).collect(Collectors.toList()); for (CommandSyntax syntax : syntaxes) { final CommandCondition commandCondition = syntax.getCommandCondition(); if (commandCondition != null && !commandCondition.canUse(sender, null)) { @@ -457,33 +455,12 @@ public final class CommandManager { final Argument argument = arguments[i]; final boolean isLast = i == arguments.length - 1; - // Search previously parsed syntaxes to find identical part in order to create a node between those - { - // Find shared part - boolean foundSharedPart = false; - for (Argument[] parsedArguments : syntaxesArguments) { - final int index = i + 1; - if (ArrayUtils.sameStart(arguments, parsedArguments, index)) { - final Argument sharedArgument = parsedArguments[i]; - final List storedNodes = storedArgumentsNodes.get(sharedArgument); - - argChildren = new IntArrayList(); - lastNodes = storedNodes.get(index); - foundSharedPart = true; - } - } - if (foundSharedPart) { - continue; - } - } - // Process the nodes for the argument { argument.processNodes(nodeMaker, isLast); // Each node array represent a layer final List nodesLayer = nodeMaker.getNodes(); - storedArgumentsNodes.put(argument, nodesLayer); for (int nodeIndex = lastArgumentNodeIndex; nodeIndex < nodesLayer.size(); nodeIndex++) { final NodeMaker.ConfiguredNodes configuredNodes = nodeMaker.getConfiguredNodes().get(nodeIndex); final NodeMaker.Options options = configuredNodes.getOptions(); @@ -520,9 +497,6 @@ public final class CommandManager { lastArgumentNodeIndex = nodesLayer.size(); } } - - syntaxesArguments.add(arguments); - } literalNode.children = ArrayUtils.toArray(cmdChildren);