2021-08-26 04:16:27 +02:00
|
|
|
From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001
|
|
|
|
From: Spottedleaf <Spottedleaf@users.noreply.github.com>
|
|
|
|
Date: Mon, 1 Feb 2021 15:35:14 -0800
|
|
|
|
Subject: [PATCH] Fix chunks refusing to unload at low TPS
|
|
|
|
|
|
|
|
The full chunk future is appended to the chunk save future, but
|
|
|
|
when moving to unloaded ticket level it is not being completed with
|
|
|
|
the empty chunk access, so the chunk save must wait for the full
|
|
|
|
chunk future to complete. We can simply schedule to the immediate
|
|
|
|
executor to get this effect, rather than the main mailbox.
|
|
|
|
|
|
|
|
diff --git a/src/main/java/net/minecraft/server/level/ChunkMap.java b/src/main/java/net/minecraft/server/level/ChunkMap.java
|
2022-09-01 18:51:59 +02:00
|
|
|
index 5a78ee69748b2b7b57a9adcff0a4718b1cc0c4ea..a3fceb2608b3be80941dfe2570999b270429e0c6 100644
|
2021-08-26 04:16:27 +02:00
|
|
|
--- a/src/main/java/net/minecraft/server/level/ChunkMap.java
|
|
|
|
+++ b/src/main/java/net/minecraft/server/level/ChunkMap.java
|
2022-09-01 18:51:59 +02:00
|
|
|
@@ -1352,9 +1352,7 @@ public class ChunkMap extends ChunkStorage implements ChunkHolder.PlayerProvider
|
2022-03-01 05:11:35 +01:00
|
|
|
|
|
|
|
return chunk;
|
2021-08-26 04:16:27 +02:00
|
|
|
});
|
|
|
|
- }, (runnable) -> {
|
2022-03-01 05:11:35 +01:00
|
|
|
- this.mainThreadMailbox.tell(ChunkTaskPriorityQueueSorter.message(holder, runnable));
|
2021-08-26 04:16:27 +02:00
|
|
|
- });
|
|
|
|
+ }, this.mainThreadExecutor); // Paper - queue to execute immediately so this doesn't delay chunk unloading
|
|
|
|
}
|
|
|
|
|
2022-03-01 05:11:35 +01:00
|
|
|
public int getTickingGenerated() {
|