mirror of
https://github.com/PaperMC/Paper.git
synced 2025-01-10 03:52:45 +01:00
SPIGOT-4563: Fix regenerating chunks saved to disk already
By: md_5 <git@md-5.net>
This commit is contained in:
parent
ec15f56573
commit
3e70f09bdf
2 changed files with 28 additions and 19 deletions
|
@ -21,7 +21,7 @@
|
||||||
this.batchScheduler = new SchedulerBatch<>(this.chunkScheduler);
|
this.batchScheduler = new SchedulerBatch<>(this.chunkScheduler);
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -112,6 +117,22 @@
|
@@ -112,6 +117,25 @@
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -31,10 +31,13 @@
|
||||||
+ this.batchScheduler.b();
|
+ this.batchScheduler.b();
|
||||||
+ ChunkCoordIntPair pos = new ChunkCoordIntPair(x, z);
|
+ ChunkCoordIntPair pos = new ChunkCoordIntPair(x, z);
|
||||||
+ this.chunkScheduler.forcePolluteCache(pos);
|
+ this.chunkScheduler.forcePolluteCache(pos);
|
||||||
|
+ ((ChunkRegionLoader) this.chunkLoader).blacklist.add(pos.a());
|
||||||
+ this.batchScheduler.a(pos);
|
+ this.batchScheduler.a(pos);
|
||||||
+ CompletableFuture<ProtoChunk> completablefuture = this.batchScheduler.c();
|
+ 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) {
|
+ } catch (RuntimeException runtimeexception) {
|
||||||
+ throw this.a(x, z, (Throwable) runtimeexception);
|
+ throw this.a(x, z, (Throwable) runtimeexception);
|
||||||
+ }
|
+ }
|
||||||
|
@ -44,7 +47,7 @@
|
||||||
public IChunkAccess a(int i, int j, boolean flag) {
|
public IChunkAccess a(int i, int j, boolean flag) {
|
||||||
Chunk chunk = this.getChunkAt(i, j, true, false);
|
Chunk chunk = this.getChunkAt(i, j, true, false);
|
||||||
|
|
||||||
@@ -249,10 +270,12 @@
|
@@ -249,10 +273,12 @@
|
||||||
Chunk chunk = (Chunk) this.chunks.get(olong);
|
Chunk chunk = (Chunk) this.chunks.get(olong);
|
||||||
|
|
||||||
if (chunk != null) {
|
if (chunk != null) {
|
||||||
|
@ -61,7 +64,7 @@
|
||||||
++i;
|
++i;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@@ -265,6 +288,42 @@
|
@@ -265,6 +291,42 @@
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -1,15 +1,16 @@
|
||||||
--- a/net/minecraft/server/ChunkRegionLoader.java
|
--- a/net/minecraft/server/ChunkRegionLoader.java
|
||||||
+++ b/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 File c;
|
||||||
private final DataFixer d;
|
private final DataFixer d;
|
||||||
private PersistentStructureLegacy e;
|
private PersistentStructureLegacy e;
|
||||||
- private boolean f;
|
- private boolean f;
|
||||||
+ // private boolean f; // CraftBukkit
|
+ // private boolean f; // CraftBukkit
|
||||||
|
+ public final LongSet blacklist = new LongOpenHashSet();
|
||||||
|
|
||||||
public ChunkRegionLoader(File file, DataFixer datafixer) {
|
public ChunkRegionLoader(File file, DataFixer datafixer) {
|
||||||
this.c = file;
|
this.c = file;
|
||||||
@@ -38,25 +38,64 @@
|
@@ -38,25 +39,69 @@
|
||||||
|
|
||||||
@Nullable
|
@Nullable
|
||||||
private NBTTagCompound a(GeneratorAccess generatoraccess, int i, int j) throws IOException {
|
private NBTTagCompound a(GeneratorAccess generatoraccess, int i, int j) throws IOException {
|
||||||
|
@ -51,6 +52,11 @@
|
||||||
@Nullable
|
@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) throws IOException {
|
||||||
+ private NBTTagCompound a(DimensionManager dimensionmanager, @Nullable PersistentCollection persistentcollection, int i, int j, @Nullable GeneratorAccess generatoraccess) 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));
|
NBTTagCompound nbttagcompound = (NBTTagCompound) this.b.get(new ChunkCoordIntPair(i, j));
|
||||||
|
|
||||||
if (nbttagcompound != null) {
|
if (nbttagcompound != null) {
|
||||||
|
@ -81,7 +87,7 @@
|
||||||
|
|
||||||
if (k < 1493) {
|
if (k < 1493) {
|
||||||
nbttagcompound1 = GameProfileSerializer.a(this.d, DataFixTypes.CHUNK, nbttagcompound1, 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);
|
Chunk chunk = this.a(generatoraccess, i, j, nbttagcompound);
|
||||||
|
|
||||||
if (chunk != null) {
|
if (chunk != null) {
|
||||||
@@ -99,6 +154,9 @@
|
@@ -99,6 +160,9 @@
|
||||||
}
|
}
|
||||||
|
|
||||||
return chunk;
|
return chunk;
|
||||||
|
@ -121,7 +127,7 @@
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -130,7 +188,7 @@
|
@@ -130,7 +194,7 @@
|
||||||
}
|
}
|
||||||
|
|
||||||
@Nullable
|
@Nullable
|
||||||
|
@ -130,7 +136,7 @@
|
||||||
if (nbttagcompound.hasKeyOfType("Level", 10) && nbttagcompound.getCompound("Level").hasKeyOfType("Status", 8)) {
|
if (nbttagcompound.hasKeyOfType("Level", 10) && nbttagcompound.getCompound("Level").hasKeyOfType("Status", 8)) {
|
||||||
ChunkStatus.Type chunkstatus_type = this.a(nbttagcompound);
|
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);
|
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("xPos", i);
|
||||||
nbttagcompound1.setInt("zPos", j);
|
nbttagcompound1.setInt("zPos", j);
|
||||||
|
@ -160,7 +166,7 @@
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
@@ -167,7 +243,7 @@
|
@@ -167,7 +249,7 @@
|
||||||
ChunkStatus.Type chunkstatus_type = this.a(nbttagcompound);
|
ChunkStatus.Type chunkstatus_type = this.a(nbttagcompound);
|
||||||
|
|
||||||
if (chunkstatus_type == ChunkStatus.Type.LEVELCHUNK) {
|
if (chunkstatus_type == ChunkStatus.Type.LEVELCHUNK) {
|
||||||
|
@ -169,7 +175,7 @@
|
||||||
} else {
|
} else {
|
||||||
NBTTagCompound nbttagcompound1 = nbttagcompound.getCompound("Level");
|
NBTTagCompound nbttagcompound1 = nbttagcompound.getCompound("Level");
|
||||||
|
|
||||||
@@ -215,10 +291,15 @@
|
@@ -215,10 +297,15 @@
|
||||||
}
|
}
|
||||||
|
|
||||||
public boolean a() {
|
public boolean a() {
|
||||||
|
@ -186,7 +192,7 @@
|
||||||
ChunkRegionLoader.a.info("ThreadedAnvilChunkStorage ({}): All chunks are saved", this.c.getName());
|
ChunkRegionLoader.a.info("ThreadedAnvilChunkStorage ({}): All chunks are saved", this.c.getName());
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -234,10 +315,14 @@
|
@@ -234,10 +321,14 @@
|
||||||
return true;
|
return true;
|
||||||
} else {
|
} else {
|
||||||
try {
|
try {
|
||||||
|
@ -202,7 +208,7 @@
|
||||||
if (this.e != null) {
|
if (this.e != null) {
|
||||||
this.e.a(chunkcoordintpair.a());
|
this.e.a(chunkcoordintpair.a());
|
||||||
}
|
}
|
||||||
@@ -264,15 +349,16 @@
|
@@ -264,15 +355,16 @@
|
||||||
|
|
||||||
public void b() {
|
public void b() {
|
||||||
try {
|
try {
|
||||||
|
@ -222,7 +228,7 @@
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
@@ -301,7 +387,7 @@
|
@@ -301,7 +393,7 @@
|
||||||
|
|
||||||
if (abiomebase != null) {
|
if (abiomebase != null) {
|
||||||
for (int k = 0; k < abiomebase.length; ++k) {
|
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];
|
int[] aint = new int[abiomebase.length];
|
||||||
|
|
||||||
for (int i = 0; i < abiomebase.length; ++i) {
|
for (int i = 0; i < abiomebase.length; ++i) {
|
||||||
|
@ -240,7 +246,7 @@
|
||||||
}
|
}
|
||||||
|
|
||||||
nbttagcompound.setIntArray("Biomes", aint);
|
nbttagcompound.setIntArray("Biomes", aint);
|
||||||
@@ -833,17 +919,29 @@
|
@@ -833,17 +925,29 @@
|
||||||
}
|
}
|
||||||
|
|
||||||
@Nullable
|
@Nullable
|
||||||
|
@ -272,7 +278,7 @@
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -857,8 +955,14 @@
|
@@ -857,8 +961,14 @@
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -288,7 +294,7 @@
|
||||||
Iterator iterator = entity.bP().iterator();
|
Iterator iterator = entity.bP().iterator();
|
||||||
|
|
||||||
while (iterator.hasNext()) {
|
while (iterator.hasNext()) {
|
||||||
@@ -874,7 +978,7 @@
|
@@ -874,7 +984,7 @@
|
||||||
boolean flag = false;
|
boolean flag = false;
|
||||||
|
|
||||||
try {
|
try {
|
||||||
|
|
Loading…
Reference in a new issue