2022-06-08 17:39:07 +00:00
|
|
|
From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001
|
|
|
|
From: David Slovikosky <davidslovikosky@gmail.com>
|
|
|
|
Date: Tue, 9 Jun 2020 00:10:03 -0700
|
|
|
|
Subject: [PATCH] Fix missing chunks due to integer overflow
|
|
|
|
|
2022-06-08 18:06:48 +00:00
|
|
|
This patch fixes a bug in the EndIslandDensityFunction class where the distance
|
2022-06-08 17:39:07 +00:00
|
|
|
from 0,0 squared overflows the maximum size of an integer. The overflow leads
|
|
|
|
to hard chunk borders around 370,000 blocks from 0,0. After this cutoff there
|
|
|
|
is a few hundred thousand block gap before end land resuming to generate at
|
|
|
|
530,000 blocks from spawn. This is due to the integer flipping back and forth.
|
|
|
|
|
|
|
|
The fix for the issue is quite simple, casting chunk coordinates to longs
|
|
|
|
allows the distance calculation to avoid overflow and work as intended.
|
|
|
|
|
|
|
|
This issue is being tracked in Mojira ticket MC-159283
|
|
|
|
|
|
|
|
diff --git a/src/main/java/net/minecraft/world/level/levelgen/DensityFunctions.java b/src/main/java/net/minecraft/world/level/levelgen/DensityFunctions.java
|
2023-09-22 17:31:02 +00:00
|
|
|
index cbebb6682740c67f9abf5c45f9a5bb9db23974c6..39927a9b24a033e95d09d2201323e2b87c1b4d4e 100644
|
2022-06-08 17:39:07 +00:00
|
|
|
--- a/src/main/java/net/minecraft/world/level/levelgen/DensityFunctions.java
|
|
|
|
+++ b/src/main/java/net/minecraft/world/level/levelgen/DensityFunctions.java
|
2022-12-07 20:16:54 +00:00
|
|
|
@@ -502,7 +502,7 @@ public final class DensityFunctions {
|
2022-07-27 20:17:18 +00:00
|
|
|
int j = z / 2;
|
|
|
|
int k = x % 2;
|
|
|
|
int l = z % 2;
|
|
|
|
- float f = 100.0F - Mth.sqrt((float)(x * x + z * z)) * 8.0F;
|
|
|
|
+ float f = 100.0F - Mth.sqrt((long) x * (long) x + (long) z * (long) z) * 8.0F; // Paper - cast ints to long to avoid integer overflow
|
2022-06-08 17:39:07 +00:00
|
|
|
f = Mth.clamp(f, -100.0F, 80.0F);
|
|
|
|
|
2022-07-27 20:17:18 +00:00
|
|
|
for(int m = -12; m <= 12; ++m) {
|