mirror of
https://github.com/Minestom/Minestom.git
synced 2025-01-04 23:47:59 +01:00
Merge pull request #426 from Kebab11noel/fix/number-range
Fix range parsing and reduce boilerplate
This commit is contained in:
commit
8fae759a71
@ -245,7 +245,7 @@ public class ArgumentEntity extends Argument<EntityFinder> {
|
|||||||
break;
|
break;
|
||||||
case "level":
|
case "level":
|
||||||
try {
|
try {
|
||||||
final IntRange level = ArgumentIntRange.staticParse(value);
|
final IntRange level = Argument.parse(new ArgumentIntRange(value));
|
||||||
entityFinder.setLevel(level);
|
entityFinder.setLevel(level);
|
||||||
} catch (ArgumentSyntaxException e) {
|
} catch (ArgumentSyntaxException e) {
|
||||||
throw new ArgumentSyntaxException("Invalid level number", input, INVALID_ARGUMENT_VALUE);
|
throw new ArgumentSyntaxException("Invalid level number", input, INVALID_ARGUMENT_VALUE);
|
||||||
@ -253,7 +253,7 @@ public class ArgumentEntity extends Argument<EntityFinder> {
|
|||||||
break;
|
break;
|
||||||
case "distance":
|
case "distance":
|
||||||
try {
|
try {
|
||||||
final IntRange distance = ArgumentIntRange.staticParse(value);
|
final IntRange distance = Argument.parse(new ArgumentIntRange(value));
|
||||||
entityFinder.setDistance(distance);
|
entityFinder.setDistance(distance);
|
||||||
} catch (ArgumentSyntaxException e) {
|
} catch (ArgumentSyntaxException e) {
|
||||||
throw new ArgumentSyntaxException("Invalid level number", input, INVALID_ARGUMENT_VALUE);
|
throw new ArgumentSyntaxException("Invalid level number", input, INVALID_ARGUMENT_VALUE);
|
||||||
|
@ -1,66 +1,16 @@
|
|||||||
package net.minestom.server.command.builder.arguments.minecraft;
|
package net.minestom.server.command.builder.arguments.minecraft;
|
||||||
|
|
||||||
import net.minestom.server.command.builder.NodeMaker;
|
|
||||||
import net.minestom.server.command.builder.exception.ArgumentSyntaxException;
|
|
||||||
import net.minestom.server.network.packet.server.play.DeclareCommandsPacket;
|
|
||||||
import net.minestom.server.utils.math.FloatRange;
|
import net.minestom.server.utils.math.FloatRange;
|
||||||
import org.jetbrains.annotations.NotNull;
|
|
||||||
|
|
||||||
import java.util.regex.Pattern;
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Represents an argument which will give you an {@link FloatRange}.
|
* Represents an argument which will give you an {@link FloatRange}.
|
||||||
* <p>
|
* <p>
|
||||||
* Example: ..3, 3.., 5..10, 15
|
* Example: ..3, 3.., 5..10, 15
|
||||||
*/
|
*/
|
||||||
public class ArgumentFloatRange extends ArgumentRange<FloatRange> {
|
public class ArgumentFloatRange extends ArgumentRange<FloatRange, Float> {
|
||||||
|
|
||||||
public ArgumentFloatRange(String id) {
|
public ArgumentFloatRange(String id) {
|
||||||
super(id);
|
super(id, "minecraft:float_range", Float.MIN_VALUE, Float.MAX_VALUE, Float::parseFloat, FloatRange::new);
|
||||||
}
|
|
||||||
|
|
||||||
@NotNull
|
|
||||||
@Override
|
|
||||||
public FloatRange parse(@NotNull String input) throws ArgumentSyntaxException {
|
|
||||||
try {
|
|
||||||
if (input.contains("..")) {
|
|
||||||
final int index = input.indexOf('.');
|
|
||||||
final String[] split = input.split(Pattern.quote(".."));
|
|
||||||
|
|
||||||
final float min;
|
|
||||||
final float max;
|
|
||||||
if (index == 0) {
|
|
||||||
// Format ..NUMBER
|
|
||||||
min = Float.MIN_VALUE;
|
|
||||||
max = Float.parseFloat(split[0]);
|
|
||||||
} else {
|
|
||||||
if (split.length == 2) {
|
|
||||||
// Format NUMBER..NUMBER
|
|
||||||
min = Float.parseFloat(split[0]);
|
|
||||||
max = Float.parseFloat(split[1]);
|
|
||||||
} else {
|
|
||||||
// Format NUMBER..
|
|
||||||
min = Float.parseFloat(split[0]);
|
|
||||||
max = Float.MAX_VALUE;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
return new FloatRange(min, max);
|
|
||||||
} else {
|
|
||||||
final float number = Float.parseFloat(input);
|
|
||||||
return new FloatRange(number);
|
|
||||||
}
|
|
||||||
} catch (NumberFormatException e2) {
|
|
||||||
throw new ArgumentSyntaxException("Invalid number", input, FORMAT_ERROR);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public void processNodes(@NotNull NodeMaker nodeMaker, boolean executable) {
|
|
||||||
DeclareCommandsPacket.Node argumentNode = simpleArgumentNode(this, executable, false, false);
|
|
||||||
argumentNode.parser = "minecraft:float_range";
|
|
||||||
|
|
||||||
nodeMaker.addNodes(new DeclareCommandsPacket.Node[]{argumentNode});
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
@ -1,76 +1,16 @@
|
|||||||
package net.minestom.server.command.builder.arguments.minecraft;
|
package net.minestom.server.command.builder.arguments.minecraft;
|
||||||
|
|
||||||
import net.minestom.server.command.builder.NodeMaker;
|
|
||||||
import net.minestom.server.command.builder.arguments.Argument;
|
|
||||||
import net.minestom.server.command.builder.exception.ArgumentSyntaxException;
|
|
||||||
import net.minestom.server.network.packet.server.play.DeclareCommandsPacket;
|
|
||||||
import net.minestom.server.utils.math.IntRange;
|
import net.minestom.server.utils.math.IntRange;
|
||||||
import org.jetbrains.annotations.NotNull;
|
|
||||||
|
|
||||||
import java.util.regex.Pattern;
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Represents an argument which will give you an {@link IntRange}.
|
* Represents an argument which will give you an {@link IntRange}.
|
||||||
* <p>
|
* <p>
|
||||||
* Example: ..3, 3.., 5..10, 15
|
* Example: ..3, 3.., 5..10, 15
|
||||||
*/
|
*/
|
||||||
public class ArgumentIntRange extends ArgumentRange<IntRange> {
|
public class ArgumentIntRange extends ArgumentRange<IntRange, Integer> {
|
||||||
|
|
||||||
public ArgumentIntRange(String id) {
|
public ArgumentIntRange(String id) {
|
||||||
super(id);
|
super(id, "minecraft:int_range", Integer.MIN_VALUE, Integer.MAX_VALUE, Integer::parseInt, IntRange::new);
|
||||||
}
|
|
||||||
|
|
||||||
@NotNull
|
|
||||||
@Override
|
|
||||||
public IntRange parse(@NotNull String input) throws ArgumentSyntaxException {
|
|
||||||
return staticParse(input);
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @deprecated use {@link Argument#parse(Argument)}
|
|
||||||
*/
|
|
||||||
@Deprecated
|
|
||||||
@NotNull
|
|
||||||
public static IntRange staticParse(@NotNull String input) throws ArgumentSyntaxException {
|
|
||||||
try {
|
|
||||||
if (input.contains("..")) {
|
|
||||||
final int index = input.indexOf('.');
|
|
||||||
final String[] split = input.split(Pattern.quote(".."));
|
|
||||||
|
|
||||||
final int min;
|
|
||||||
final int max;
|
|
||||||
if (index == 0) {
|
|
||||||
// Format ..NUMBER
|
|
||||||
min = Integer.MIN_VALUE;
|
|
||||||
max = Integer.parseInt(split[0]);
|
|
||||||
} else {
|
|
||||||
if (split.length == 2) {
|
|
||||||
// Format NUMBER..NUMBER
|
|
||||||
min = Integer.parseInt(split[0]);
|
|
||||||
max = Integer.parseInt(split[1]);
|
|
||||||
} else {
|
|
||||||
// Format NUMBER..
|
|
||||||
min = Integer.parseInt(split[0]);
|
|
||||||
max = Integer.MAX_VALUE;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
return new IntRange(min, max);
|
|
||||||
} else {
|
|
||||||
final int number = Integer.parseInt(input);
|
|
||||||
return new IntRange(number);
|
|
||||||
}
|
|
||||||
} catch (NumberFormatException e2) {
|
|
||||||
throw new ArgumentSyntaxException("Invalid number", input, FORMAT_ERROR);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public void processNodes(@NotNull NodeMaker nodeMaker, boolean executable) {
|
|
||||||
DeclareCommandsPacket.Node argumentNode = simpleArgumentNode(this, executable, false, false);
|
|
||||||
argumentNode.parser = "minecraft:int_range";
|
|
||||||
|
|
||||||
nodeMaker.addNodes(new DeclareCommandsPacket.Node[]{argumentNode});
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
@ -1,17 +1,81 @@
|
|||||||
package net.minestom.server.command.builder.arguments.minecraft;
|
package net.minestom.server.command.builder.arguments.minecraft;
|
||||||
|
|
||||||
|
import net.minestom.server.command.builder.NodeMaker;
|
||||||
import net.minestom.server.command.builder.arguments.Argument;
|
import net.minestom.server.command.builder.arguments.Argument;
|
||||||
|
import net.minestom.server.command.builder.exception.ArgumentSyntaxException;
|
||||||
|
import net.minestom.server.network.packet.server.play.DeclareCommandsPacket;
|
||||||
|
import net.minestom.server.utils.math.Range;
|
||||||
|
import org.jetbrains.annotations.NotNull;
|
||||||
|
|
||||||
|
import java.util.function.BiFunction;
|
||||||
|
import java.util.function.Function;
|
||||||
|
import java.util.regex.Pattern;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Abstract class used by {@link ArgumentIntRange} and {@link ArgumentFloatRange}.
|
* Abstract class used by {@link ArgumentIntRange} and {@link ArgumentFloatRange}.
|
||||||
*
|
*
|
||||||
* @param <T> the type of the range
|
* @param <T> the type of the range
|
||||||
*/
|
*/
|
||||||
public abstract class ArgumentRange<T> extends Argument<T> {
|
public abstract class ArgumentRange<T extends Range<N>, N extends Number> extends Argument<T> {
|
||||||
|
|
||||||
public static final int FORMAT_ERROR = -1;
|
public static final int FORMAT_ERROR = -1;
|
||||||
|
private final N min;
|
||||||
|
private final N max;
|
||||||
|
private final Function<String, N> parser;
|
||||||
|
private final String parserName;
|
||||||
|
private final BiFunction<N, N, T> rangeConstructor;
|
||||||
|
|
||||||
public ArgumentRange(String id) {
|
public ArgumentRange(@NotNull String id, String parserName, N min, N max, Function<String, N> parser, BiFunction<N, N, T> rangeConstructor) {
|
||||||
super(id);
|
super(id);
|
||||||
|
this.min = min;
|
||||||
|
this.max = max;
|
||||||
|
this.parser = parser;
|
||||||
|
this.parserName = parserName;
|
||||||
|
this.rangeConstructor = rangeConstructor;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@NotNull
|
||||||
|
@Override
|
||||||
|
public T parse(@NotNull String input) throws ArgumentSyntaxException {
|
||||||
|
try {
|
||||||
|
final String[] split = input.split(Pattern.quote(".."), -1);
|
||||||
|
|
||||||
|
if (split.length == 2) {
|
||||||
|
final N min;
|
||||||
|
final N max;
|
||||||
|
if (split[0].length() == 0 && split[1].length() > 0) {
|
||||||
|
// Format ..NUMBER
|
||||||
|
min = this.min;
|
||||||
|
max = parser.apply(split[1]);
|
||||||
|
} else if (split[0].length() > 0 && split[1].length() == 0) {
|
||||||
|
// Format NUMBER..
|
||||||
|
min = parser.apply(split[0]);
|
||||||
|
max = this.max;
|
||||||
|
} else if (split[0].length() > 0) {
|
||||||
|
// Format NUMBER..NUMBER
|
||||||
|
min = parser.apply(split[0]);
|
||||||
|
max = parser.apply(split[1]);
|
||||||
|
} else {
|
||||||
|
// Format ..
|
||||||
|
throw new ArgumentSyntaxException("Invalid range format", input, FORMAT_ERROR);
|
||||||
|
}
|
||||||
|
return rangeConstructor.apply(min, max);
|
||||||
|
} else if (split.length == 1) {
|
||||||
|
final N number = parser.apply(input);
|
||||||
|
return rangeConstructor.apply(number, number);
|
||||||
|
}
|
||||||
|
} catch (NumberFormatException e2) {
|
||||||
|
throw new ArgumentSyntaxException("Invalid number", input, FORMAT_ERROR);
|
||||||
|
}
|
||||||
|
throw new ArgumentSyntaxException("Invalid range format", input, FORMAT_ERROR);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void processNodes(@NotNull NodeMaker nodeMaker, boolean executable) {
|
||||||
|
DeclareCommandsPacket.Node argumentNode = simpleArgumentNode(this, executable, false, false);
|
||||||
|
argumentNode.parser = parserName;
|
||||||
|
|
||||||
|
nodeMaker.addNodes(new DeclareCommandsPacket.Node[]{argumentNode});
|
||||||
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user