Merge pull request #103 from mikeprimm/fix_1_13_border_chunks

Alter fully generated prediction to match 1.13.x worldgen behavior
This commit is contained in:
Brett Flannigan 2018-09-16 09:30:31 -05:00 committed by GitHub
commit e5feeb1b75
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
2 changed files with 22 additions and 9 deletions

5
.gitignore vendored
View File

@ -1,4 +1,7 @@
target/
bin/
.idea/
*.iml
.classpath
.project
.settings/

View File

@ -134,14 +134,15 @@ public class WorldFileData
// Minecraft only fully generates a chunk when adjacent chunks are also loaded.
public boolean isChunkFullyGenerated(int x, int z)
{ // if all adjacent chunks exist, it should be a safe enough bet that this one is fully generated
return
! (
! doesChunkExist(x, z)
|| ! doesChunkExist(x+1, z)
|| ! doesChunkExist(x-1, z)
|| ! doesChunkExist(x, z+1)
|| ! doesChunkExist(x, z-1)
);
// For 1.13+, due to world gen changes, this is now effectively a 3 chunk radius requirement vs a 1 chunk radius
for (int xx = x-3; xx <= x+3; xx++) {
for (int zz = z-3; zz <= z+3; zz++) {
if (!doesChunkExist(xx, zz)) {
return false;
}
}
}
return true;
}
// Method to let us know a chunk has been generated, to update our region map.
@ -199,6 +200,15 @@ public class WorldFileData
if (regionData.readInt() != 0)
data.set(j, true);
counter++;
}
// Read timestamps
for (int j = 0; j < 1024; j++)
{
// if timestamp is zero, it is protochunk (ignore it)
if ((regionData.readInt() == 0) && data.get(j)) {
data.set(j, false);
}
counter++;
}
regionData.close();
}