fix mix check

This commit is contained in:
Németh Noel 2021-07-09 19:57:59 +02:00
parent 2efefe25b3
commit 8e5d2f0dfe
2 changed files with 14 additions and 8 deletions

View File

@ -10,6 +10,8 @@ import org.jetbrains.annotations.NotNull;
import java.util.Set; import java.util.Set;
import java.util.function.Function; import java.util.function.Function;
import static net.minestom.server.utils.location.RelativeVec.CoordinateType.*;
/** /**
* Common interface for all the relative location arguments. * Common interface for all the relative location arguments.
*/ */
@ -44,7 +46,7 @@ abstract class ArgumentRelativeVec extends Argument<RelativeVec> {
double[] coordinates = new double[split.length]; double[] coordinates = new double[split.length];
boolean[] isRelative = new boolean[split.length]; boolean[] isRelative = new boolean[split.length];
var type = RelativeVec.CoordinateType.UNDEFINED; var type = UNDEFINED;
for (int i = 0; i < split.length; i++) { for (int i = 0; i < split.length; i++) {
final String element = split[i]; final String element = split[i];
try { try {
@ -52,9 +54,9 @@ abstract class ArgumentRelativeVec extends Argument<RelativeVec> {
if (MODIFIER_CHARS.contains(modifierChar)) { if (MODIFIER_CHARS.contains(modifierChar)) {
isRelative[i] = true; isRelative[i] = true;
if (type == RelativeVec.CoordinateType.UNDEFINED) { if (type == UNDEFINED) {
type = modifierChar == LOCAL_CHAR ? RelativeVec.CoordinateType.LOCAL : RelativeVec.CoordinateType.RELATIVE; type = modifierChar == LOCAL_CHAR ? LOCAL : RELATIVE;
} else if (type != (modifierChar == LOCAL_CHAR ? RelativeVec.CoordinateType.LOCAL : RelativeVec.CoordinateType.RELATIVE)) { } else if (type != (modifierChar == LOCAL_CHAR ? LOCAL : RELATIVE)) {
throw new ArgumentSyntaxException("Cannot mix world & local coordinates (everything must either use ^ or not)", input, MIXED_TYPE_ERROR); throw new ArgumentSyntaxException("Cannot mix world & local coordinates (everything must either use ^ or not)", input, MIXED_TYPE_ERROR);
} }
@ -63,6 +65,11 @@ abstract class ArgumentRelativeVec extends Argument<RelativeVec> {
coordinates[i] = getRelativeNumberParser().apply(potentialNumber).doubleValue(); coordinates[i] = getRelativeNumberParser().apply(potentialNumber).doubleValue();
} }
} else { } else {
if (type == UNDEFINED) {
type = ABSOLUTE;
} else if (type == LOCAL) {
throw new ArgumentSyntaxException("Cannot mix world & local coordinates (everything must either use ^ or not)", input, MIXED_TYPE_ERROR);
}
coordinates[i] = getAbsoluteNumberParser().apply(element).doubleValue(); coordinates[i] = getAbsoluteNumberParser().apply(element).doubleValue();
} }
} catch (NumberFormatException e) { } catch (NumberFormatException e) {

View File

@ -123,11 +123,10 @@ public final class RelativeVec {
double double14 = dna11.x() * local.z() + dna12.x() * local.y() + dna13.x() * local.x(); double double14 = dna11.x() * local.z() + dna12.x() * local.y() + dna13.x() * local.x();
double double16 = dna11.y() * local.z() + dna12.y() * local.y() + dna13.y() * local.x(); double double16 = dna11.y() * local.z() + dna12.y() * local.y() + dna13.y() * local.x();
double double18 = dna11.z() * local.z() + dna12.z() * local.y() + dna13.z() * local.x(); double double18 = dna11.z() * local.z() + dna12.z() * local.y() + dna13.z() * local.x();
return new Vec(double14 + (relativeX ? origin.x() : 0), return new Vec(double14 + origin.x(),double16 + origin.y(),double18 + origin.z());
double16 + (relativeY ? origin.y() : 0),
double18 + (relativeZ ? origin.z() : 0));
}), }),
UNDEFINED((vec, origin, relativeX, relativeY, relativeZ) -> vec); ABSOLUTE(((vec, origin, relativeX1, relativeY1, relativeZ1) -> vec)),
UNDEFINED((vec, origin, relativeX, relativeY, relativeZ) -> Vec.ZERO);
private final CoordinateConverter converter; private final CoordinateConverter converter;