SPIGOT-4563: Fix regenerating chunks saved to disk already

By: md_5 <git@md-5.net>
This commit is contained in:
CraftBukkit/Spigot 2019-01-03 15:44:06 +11:00
parent ec15f56573
commit 3e70f09bdf
2 changed files with 28 additions and 19 deletions

View file

@ -21,7 +21,7 @@
this.batchScheduler = new SchedulerBatch<>(this.chunkScheduler);
}
@@ -112,6 +117,22 @@
@@ -112,6 +117,25 @@
}
}
@ -31,10 +31,13 @@
+ this.batchScheduler.b();
+ ChunkCoordIntPair pos = new ChunkCoordIntPair(x, z);
+ this.chunkScheduler.forcePolluteCache(pos);
+ ((ChunkRegionLoader) this.chunkLoader).blacklist.add(pos.a());
+ this.batchScheduler.a(pos);
+ CompletableFuture<ProtoChunk> completablefuture = this.batchScheduler.c();
+
+ return (Chunk) completablefuture.thenApply(this::a).join();
+ Chunk chunk = (Chunk) completablefuture.thenApply(this::a).join();
+ ((ChunkRegionLoader) this.chunkLoader).blacklist.remove(pos.a());
+ return chunk;
+ } catch (RuntimeException runtimeexception) {
+ throw this.a(x, z, (Throwable) runtimeexception);
+ }
@ -44,7 +47,7 @@
public IChunkAccess a(int i, int j, boolean flag) {
Chunk chunk = this.getChunkAt(i, j, true, false);
@@ -249,10 +270,12 @@
@@ -249,10 +273,12 @@
Chunk chunk = (Chunk) this.chunks.get(olong);
if (chunk != null) {
@ -61,7 +64,7 @@
++i;
}
}
@@ -265,6 +288,42 @@
@@ -265,6 +291,42 @@
return false;
}

View file

@ -1,15 +1,16 @@
--- a/net/minecraft/server/ChunkRegionLoader.java
+++ b/net/minecraft/server/ChunkRegionLoader.java
@@ -29,7 +29,7 @@
@@ -29,7 +29,8 @@
private final File c;
private final DataFixer d;
private PersistentStructureLegacy e;
- private boolean f;
+ // private boolean f; // CraftBukkit
+ public final LongSet blacklist = new LongOpenHashSet();
public ChunkRegionLoader(File file, DataFixer datafixer) {
this.c = file;
@@ -38,25 +38,64 @@
@@ -38,25 +39,69 @@
@Nullable
private NBTTagCompound a(GeneratorAccess generatoraccess, int i, int j) throws IOException {
@ -51,6 +52,11 @@
@Nullable
- private NBTTagCompound a(DimensionManager dimensionmanager, @Nullable PersistentCollection persistentcollection, int i, int j) throws IOException {
+ private NBTTagCompound a(DimensionManager dimensionmanager, @Nullable PersistentCollection persistentcollection, int i, int j, @Nullable GeneratorAccess generatoraccess) throws IOException {
+ // CraftBukkit start
+ if (blacklist.contains(ChunkCoordIntPair.a(i, j))) {
+ return null;
+ }
+ // CraftBukkit end
NBTTagCompound nbttagcompound = (NBTTagCompound) this.b.get(new ChunkCoordIntPair(i, j));
if (nbttagcompound != null) {
@ -81,7 +87,7 @@
if (k < 1493) {
nbttagcompound1 = GameProfileSerializer.a(this.d, DataFixTypes.CHUNK, nbttagcompound1, k, 1493);
@@ -84,13 +123,29 @@
@@ -84,13 +129,29 @@
}
@ -111,7 +117,7 @@
Chunk chunk = this.a(generatoraccess, i, j, nbttagcompound);
if (chunk != null) {
@@ -99,6 +154,9 @@
@@ -99,6 +160,9 @@
}
return chunk;
@ -121,7 +127,7 @@
}
}
@@ -130,7 +188,7 @@
@@ -130,7 +194,7 @@
}
@Nullable
@ -130,7 +136,7 @@
if (nbttagcompound.hasKeyOfType("Level", 10) && nbttagcompound.getCompound("Level").hasKeyOfType("Status", 8)) {
ChunkStatus.Type chunkstatus_type = this.a(nbttagcompound);
@@ -149,10 +207,28 @@
@@ -149,10 +213,28 @@
ChunkRegionLoader.a.error("Chunk file at {},{} is in the wrong location; relocating. (Expected {}, {}, got {}, {})", i, j, i, j, chunk.locX, chunk.locZ);
nbttagcompound1.setInt("xPos", i);
nbttagcompound1.setInt("zPos", j);
@ -160,7 +166,7 @@
}
}
} else {
@@ -167,7 +243,7 @@
@@ -167,7 +249,7 @@
ChunkStatus.Type chunkstatus_type = this.a(nbttagcompound);
if (chunkstatus_type == ChunkStatus.Type.LEVELCHUNK) {
@ -169,7 +175,7 @@
} else {
NBTTagCompound nbttagcompound1 = nbttagcompound.getCompound("Level");
@@ -215,10 +291,15 @@
@@ -215,10 +297,15 @@
}
public boolean a() {
@ -186,7 +192,7 @@
ChunkRegionLoader.a.info("ThreadedAnvilChunkStorage ({}): All chunks are saved", this.c.getName());
}
@@ -234,10 +315,14 @@
@@ -234,10 +321,14 @@
return true;
} else {
try {
@ -202,7 +208,7 @@
if (this.e != null) {
this.e.a(chunkcoordintpair.a());
}
@@ -264,15 +349,16 @@
@@ -264,15 +355,16 @@
public void b() {
try {
@ -222,7 +228,7 @@
}
}
@@ -301,7 +387,7 @@
@@ -301,7 +393,7 @@
if (abiomebase != null) {
for (int k = 0; k < abiomebase.length; ++k) {
@ -231,7 +237,7 @@
}
}
@@ -383,7 +469,7 @@
@@ -383,7 +475,7 @@
int[] aint = new int[abiomebase.length];
for (int i = 0; i < abiomebase.length; ++i) {
@ -240,7 +246,7 @@
}
nbttagcompound.setIntArray("Biomes", aint);
@@ -833,17 +919,29 @@
@@ -833,17 +925,29 @@
}
@Nullable
@ -272,7 +278,7 @@
});
}
@@ -857,8 +955,14 @@
@@ -857,8 +961,14 @@
}
}
@ -288,7 +294,7 @@
Iterator iterator = entity.bP().iterator();
while (iterator.hasNext()) {
@@ -874,7 +978,7 @@
@@ -874,7 +984,7 @@
boolean flag = false;
try {