From 1619cedc53a4e72d2cc1fad6f7246ee12ff746c0 Mon Sep 17 00:00:00 2001 From: mworzala Date: Fri, 9 Feb 2024 10:21:42 -0500 Subject: [PATCH] chore: add checks when creating dimension types to client registry errors --- .../minestom/server/world/DimensionType.java | 20 ++++++++++++++++--- 1 file changed, 17 insertions(+), 3 deletions(-) diff --git a/src/main/java/net/minestom/server/world/DimensionType.java b/src/main/java/net/minestom/server/world/DimensionType.java index 71f1d402266..553e683a2cc 100644 --- a/src/main/java/net/minestom/server/world/DimensionType.java +++ b/src/main/java/net/minestom/server/world/DimensionType.java @@ -1,6 +1,7 @@ package net.minestom.server.world; import net.minestom.server.utils.NamespaceID; +import net.minestom.server.utils.validate.Check; import org.jetbrains.annotations.NotNull; import org.jetbrains.annotations.Nullable; import org.jglrxavpok.hephaistos.mcdata.SizesKt; @@ -64,6 +65,15 @@ public class DimensionType { boolean skylightEnabled, @Nullable Long fixedTime, boolean raidCapable, boolean respawnAnchorSafe, boolean ultrawarm, boolean bedSafe, String effects, boolean piglinSafe, int minY, int height, int logicalHeight, double coordinateScale, NamespaceID infiniburn) { + Check.argCondition(minY < -2032, "minY cannot be lower than -2032"); + Check.argCondition(minY > 2031, "minY cannot be higher than 2031"); + Check.argCondition(minY % 16 != 0, "minY must be a multiple of 16"); + Check.argCondition(height < 16, "height cannot be lower than 16"); + Check.argCondition(height > 4064, "height cannot be higher than 4064"); + Check.argCondition(height % 16 != 0, "height must be a multiple of 16"); + Check.argCondition(minY + height > 2031, "buildable height (minY + height) cannot be higher than 2031"); + Check.argCondition(logicalHeight > height, "logicalHeight cannot be higher than height"); + this.name = name; this.natural = natural; this.ambientLight = ambientLight; @@ -356,9 +366,13 @@ public DimensionType.DimensionTypeBuilder infiniburn(NamespaceID infiniburn) { } public DimensionType build() { - return new DimensionType(name, natural, ambientLight, ceilingEnabled, skylightEnabled, - fixedTime, raidCapable, respawnAnchorSafe, ultrawarm, bedSafe, effects, - piglinSafe, minY, height, logicalHeight, coordinateScale, infiniburn); + try { + return new DimensionType(name, natural, ambientLight, ceilingEnabled, skylightEnabled, + fixedTime, raidCapable, respawnAnchorSafe, ultrawarm, bedSafe, effects, + piglinSafe, minY, height, logicalHeight, coordinateScale, infiniburn); + } catch (IllegalArgumentException e) { + throw new IllegalArgumentException("Invalid dimension type (" + name + "): " + e.getMessage()); + } } } }