From 91e0cdf283027ae63a210caf8c87950e25205489 Mon Sep 17 00:00:00 2001 From: "Lukas Rieger (Blue)" Date: Mon, 6 Jan 2025 16:47:40 +0100 Subject: [PATCH] Account for possible integer-parse exception if there are WAY too many digits in the file-name-pattern --- .../core/world/mca/region/RegionType.java | 25 +++++++++++++------ 1 file changed, 17 insertions(+), 8 deletions(-) diff --git a/core/src/main/java/de/bluecolored/bluemap/core/world/mca/region/RegionType.java b/core/src/main/java/de/bluecolored/bluemap/core/world/mca/region/RegionType.java index fa6792f6..4f4ffcf6 100644 --- a/core/src/main/java/de/bluecolored/bluemap/core/world/mca/region/RegionType.java +++ b/core/src/main/java/de/bluecolored/bluemap/core/world/mca/region/RegionType.java @@ -25,6 +25,7 @@ package de.bluecolored.bluemap.core.world.mca.region; import com.flowpowered.math.vector.Vector2i; +import de.bluecolored.bluemap.core.logger.Logger; import de.bluecolored.bluemap.core.util.Key; import de.bluecolored.bluemap.core.util.Keyed; import de.bluecolored.bluemap.core.util.Registry; @@ -114,16 +115,24 @@ public String getRegionFileName(int regionX, int regionZ) { Matcher matcher = regionFileNamePattern.matcher(fileName); if (!matcher.matches()) return null; - int regionX = Integer.parseInt(matcher.group(1)); - int regionZ = Integer.parseInt(matcher.group(2)); + try { - // sanity-check for roughly minecraft max boundaries (-30 000 000 to 30 000 000) - if ( - regionX < -100000 || regionX > 100000 || - regionZ < -100000 || regionZ > 100000 - ) return null; + int regionX = Integer.parseInt(matcher.group(1)); + int regionZ = Integer.parseInt(matcher.group(2)); - return new Vector2i(regionX, regionZ); + // sanity-check for roughly minecraft max boundaries (-30 000 000 to 30 000 000) + if ( + regionX < -100000 || regionX > 100000 || + regionZ < -100000 || regionZ > 100000 + ) { + return null; + } + + return new Vector2i(regionX, regionZ); + + } catch (NumberFormatException ex) { + return null; + } } }