mirror of
https://github.com/Minestom/Minestom.git
synced 2025-01-10 02:17:41 +01:00
ArgumentEntity static fields naming fix
This commit is contained in:
parent
eda821c3d8
commit
266c4d9bed
@ -13,8 +13,6 @@ import org.jetbrains.annotations.NotNull;
|
|||||||
import java.util.Arrays;
|
import java.util.Arrays;
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
|
|
||||||
// TODO
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Represents the target selector argument.
|
* Represents the target selector argument.
|
||||||
* https://minecraft.gamepedia.com/Commands#Target_selectors
|
* https://minecraft.gamepedia.com/Commands#Target_selectors
|
||||||
@ -28,22 +26,23 @@ public class ArgumentEntity extends Argument<EntityFinder> {
|
|||||||
public static final int INVALID_ARGUMENT_VALUE = -6;
|
public static final int INVALID_ARGUMENT_VALUE = -6;
|
||||||
|
|
||||||
private static final String SELECTOR_PREFIX = "@";
|
private static final String SELECTOR_PREFIX = "@";
|
||||||
private static final List<String> selectorVariables = Arrays.asList("@p", "@r", "@a", "@e", "@s");
|
private static final List<String> SELECTOR_VARIABLES = Arrays.asList("@p", "@r", "@a", "@e", "@s");
|
||||||
private static final List<String> playersOnlySelector = Arrays.asList("@p", "@r", "@a", "@s");
|
private static final List<String> PLAYERS_ONLY_SELECTOR = Arrays.asList("@p", "@r", "@a", "@s");
|
||||||
private static final List<String> singleOnlySelector = Arrays.asList("@p", "@r", "@s");
|
private static final List<String> SINGLE_ONLY_SELECTOR = Arrays.asList("@p", "@r", "@s");
|
||||||
// List with all the valid arguments
|
// List with all the valid arguments
|
||||||
private static final List<String> validArguments = Arrays.asList(
|
private static final List<String> VALID_ARGUMENTS = Arrays.asList(
|
||||||
"x", "y", "z",
|
"x", "y", "z",
|
||||||
"distance", "dx", "dy", "dz",
|
"distance", "dx", "dy", "dz",
|
||||||
"scores", "tag", "team", "limit", "sort", "level", "gamemode", "name",
|
"scores", "tag", "team", "limit", "sort", "level", "gamemode", "name",
|
||||||
"x_rotation", "y_rotation", "type", "nbt", "advancements", "predicate");
|
"x_rotation", "y_rotation", "type", "nbt", "advancements", "predicate");
|
||||||
|
|
||||||
// List with all the easily parsable arguments which only require reading until a specific character (comma)
|
// List with all the easily parsable arguments which only require reading until a specific character (comma)
|
||||||
private static final List<String> simpleArguments = Arrays.asList(
|
private static final List<String> SIMPLE_ARGUMENTS = Arrays.asList(
|
||||||
"x", "y", "z",
|
"x", "y", "z",
|
||||||
"distance", "dx", "dy", "dz",
|
"distance", "dx", "dy", "dz",
|
||||||
"scores", "tag", "team", "limit", "sort", "level", "gamemode",
|
"scores", "tag", "team", "limit", "sort", "level", "gamemode",
|
||||||
"x_rotation", "y_rotation", "type", "advancements", "predicate");
|
"x_rotation", "y_rotation", "type", "advancements", "predicate");
|
||||||
|
|
||||||
private boolean onlySingleEntity;
|
private boolean onlySingleEntity;
|
||||||
private boolean onlyPlayers;
|
private boolean onlyPlayers;
|
||||||
|
|
||||||
@ -96,7 +95,7 @@ public class ArgumentEntity extends Argument<EntityFinder> {
|
|||||||
.setName(input, EntityFinder.ToggleableType.INCLUDE);
|
.setName(input, EntityFinder.ToggleableType.INCLUDE);
|
||||||
}
|
}
|
||||||
|
|
||||||
// The minimum size is always 0 (for the selector variable, ex: @p)
|
// The minimum size is always 2 (for the selector variable, ex: @p)
|
||||||
if (input.length() < 2)
|
if (input.length() < 2)
|
||||||
throw new ArgumentSyntaxException("Length needs to be > 1", input, INVALID_SYNTAX);
|
throw new ArgumentSyntaxException("Length needs to be > 1", input, INVALID_SYNTAX);
|
||||||
|
|
||||||
@ -107,15 +106,15 @@ public class ArgumentEntity extends Argument<EntityFinder> {
|
|||||||
final String selectorVariable = input.substring(0, 2);
|
final String selectorVariable = input.substring(0, 2);
|
||||||
|
|
||||||
// Check if the selector variable used exists
|
// Check if the selector variable used exists
|
||||||
if (!selectorVariables.contains(selectorVariable))
|
if (!SELECTOR_VARIABLES.contains(selectorVariable))
|
||||||
throw new ArgumentSyntaxException("Invalid selector variable", input, INVALID_SYNTAX);
|
throw new ArgumentSyntaxException("Invalid selector variable", input, INVALID_SYNTAX);
|
||||||
|
|
||||||
// Check if it should only select single entity and if the selector variable valid the condition
|
// Check if it should only select single entity and if the selector variable valid the condition
|
||||||
if (onlySingleEntity && !singleOnlySelector.contains(selectorVariable))
|
if (onlySingleEntity && !SINGLE_ONLY_SELECTOR.contains(selectorVariable))
|
||||||
throw new ArgumentSyntaxException("Argument requires only a single entity", input, ONLY_SINGLE_ENTITY_ERROR);
|
throw new ArgumentSyntaxException("Argument requires only a single entity", input, ONLY_SINGLE_ENTITY_ERROR);
|
||||||
|
|
||||||
// Check if it should only select players and if the selector variable valid the condition
|
// Check if it should only select players and if the selector variable valid the condition
|
||||||
if (onlyPlayers && !playersOnlySelector.contains(selectorVariable))
|
if (onlyPlayers && !PLAYERS_ONLY_SELECTOR.contains(selectorVariable))
|
||||||
throw new ArgumentSyntaxException("Argument requires only players", input, ONLY_PLAYERS_ERROR);
|
throw new ArgumentSyntaxException("Argument requires only players", input, ONLY_PLAYERS_ERROR);
|
||||||
|
|
||||||
// Create the EntityFinder which will be used for the rest of the parsing
|
// Create the EntityFinder which will be used for the rest of the parsing
|
||||||
@ -151,7 +150,7 @@ public class ArgumentEntity extends Argument<EntityFinder> {
|
|||||||
// Replace all unnecessary spaces
|
// Replace all unnecessary spaces
|
||||||
currentArgument = currentArgument.trim();
|
currentArgument = currentArgument.trim();
|
||||||
|
|
||||||
if (!validArguments.contains(currentArgument))
|
if (!VALID_ARGUMENTS.contains(currentArgument))
|
||||||
throw new ArgumentSyntaxException("Argument name '" + currentArgument + "' does not exist", input, INVALID_ARGUMENT_NAME);
|
throw new ArgumentSyntaxException("Argument name '" + currentArgument + "' does not exist", input, INVALID_ARGUMENT_NAME);
|
||||||
|
|
||||||
i = parseArgument(entityFinder, currentArgument, input, structureData, i);
|
i = parseArgument(entityFinder, currentArgument, input, structureData, i);
|
||||||
@ -169,7 +168,7 @@ public class ArgumentEntity extends Argument<EntityFinder> {
|
|||||||
@NotNull String input,
|
@NotNull String input,
|
||||||
@NotNull String structureData, int beginIndex) throws ArgumentSyntaxException {
|
@NotNull String structureData, int beginIndex) throws ArgumentSyntaxException {
|
||||||
final char comma = ',';
|
final char comma = ',';
|
||||||
final boolean isSimple = simpleArguments.contains(argumentName);
|
final boolean isSimple = SIMPLE_ARGUMENTS.contains(argumentName);
|
||||||
|
|
||||||
int finalIndex = beginIndex + 1;
|
int finalIndex = beginIndex + 1;
|
||||||
StringBuilder valueBuilder = new StringBuilder();
|
StringBuilder valueBuilder = new StringBuilder();
|
||||||
|
Loading…
Reference in New Issue
Block a user