2019-01-01 11:15:55 +08:00
|
|
|
From 2e7dfd9a66cf68126c90c5a3a591f0acc5814990 Mon Sep 17 00:00:00 2001
|
2017-01-08 05:08:16 +08:00
|
|
|
From: Aikar <aikar@aikar.co>
|
|
|
|
Date: Sat, 7 Jan 2017 16:06:44 -0500
|
|
|
|
Subject: [PATCH] Enforce Sync Chunk Unloads
|
|
|
|
|
|
|
|
Unloading Chunks async is extremely dangerous. This will force it to main
|
|
|
|
the same way we handle async chunk loads.
|
|
|
|
|
|
|
|
diff --git a/src/main/java/org/bukkit/craftbukkit/CraftWorld.java b/src/main/java/org/bukkit/craftbukkit/CraftWorld.java
|
2019-01-01 11:15:55 +08:00
|
|
|
index 864151444..0f3bf13ef 100644
|
2017-01-08 05:08:16 +08:00
|
|
|
--- a/src/main/java/org/bukkit/craftbukkit/CraftWorld.java
|
|
|
|
+++ b/src/main/java/org/bukkit/craftbukkit/CraftWorld.java
|
2019-01-01 11:15:55 +08:00
|
|
|
@@ -236,6 +236,7 @@ public class CraftWorld implements World {
|
2017-01-08 05:08:16 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
private boolean unloadChunk0(int x, int z, boolean save) {
|
|
|
|
+ Boolean result = MCUtil.ensureMain("Unload Chunk", () -> { // Paper - Ensure never async
|
2018-12-17 13:18:06 +08:00
|
|
|
net.minecraft.server.Chunk chunk = world.getChunkProvider().getChunkAt(x, z, false, false);
|
2017-01-08 05:08:16 +08:00
|
|
|
if (chunk == null) {
|
|
|
|
return true;
|
2019-01-01 11:15:55 +08:00
|
|
|
@@ -243,6 +244,7 @@ public class CraftWorld implements World {
|
2017-01-08 05:08:16 +08:00
|
|
|
|
|
|
|
// If chunk had previously been queued to save, must do save to avoid loss of that data
|
2018-12-17 13:18:06 +08:00
|
|
|
return world.getChunkProvider().unloadChunk(chunk, chunk.mustSave || save);
|
2017-01-08 05:08:16 +08:00
|
|
|
+ }); return result != null ? result : false; // Paper - Ensure never async
|
|
|
|
}
|
|
|
|
|
|
|
|
public boolean regenerateChunk(int x, int z) {
|
|
|
|
--
|
2019-01-01 11:15:55 +08:00
|
|
|
2.20.1
|
2017-01-08 05:08:16 +08:00
|
|
|
|