Remove chunk unload trace debug

The issue the patch was initially added for has already been fixed and filling stacktraces can be expensive
Dieser Commit ist enthalten in:
Nassim Jahnke 2024-08-05 19:57:34 +02:00
Ursprung df3b6544f7
Commit 5a5c3a4a24
Es konnte kein GPG-Schlüssel zu dieser Signatur gefunden werden
GPG-Schlüssel-ID: EF6771C01F6EF02F
17 geänderte Dateien mit 0 neuen und 57 gelöschten Zeilen

Datei anzeigen

@ -1,57 +0,0 @@
From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001
From: Spottedleaf <Spottedleaf@users.noreply.github.com>
Date: Wed, 19 Jun 2024 10:52:07 -0700
Subject: [PATCH] Add debug for chunk system unload crash
Somehow, a chunkholder is present in the unload queue after
it has been unloaded. It is likely that this is a result of
adding the chunk holder to the unload queue while it is
unloading. However, that should not be possible.
To find out where it is being added to the unload queue, track
the last stacktrace which adds to the unload queue and check
on chunk holder remove if the holder is present in the unload queue
and log the stacktrace.
diff --git a/src/main/java/ca/spottedleaf/moonrise/patches/chunk_system/scheduling/NewChunkHolder.java b/src/main/java/ca/spottedleaf/moonrise/patches/chunk_system/scheduling/NewChunkHolder.java
index 1dfddea4fd7e89fb6fd9fa49f7ab5e6f48e6ef3c..4068138e4ec0ccb02f5925f8b5a31381882f08e0 100644
--- a/src/main/java/ca/spottedleaf/moonrise/patches/chunk_system/scheduling/NewChunkHolder.java
+++ b/src/main/java/ca/spottedleaf/moonrise/patches/chunk_system/scheduling/NewChunkHolder.java
@@ -749,9 +749,22 @@ public final class NewChunkHolder {
/** Unloaded from chunk map */
private boolean unloaded;
+ private Throwable lastUnloadAdd;
void markUnloaded() {
this.unloaded = true;
+ if (this.inUnloadQueue) {
+ if (this.lastUnloadAdd != null) {
+ LOGGER.error("Unloaded chunkholder " + this.toString() + " while in the unload queue", this.lastUnloadAdd);
+ } else {
+ // should never happen
+ LOGGER.error("Unloaded chunkholder " + this.toString() + " while in the unload queue without a throwable");
+ }
+
+ // prevent crash by removing (note: we hold scheduling lock here)
+ this.inUnloadQueue = false;
+ this.scheduler.chunkHolderManager.unloadQueue.removeChunk(this.chunkX, this.chunkZ);
+ }
}
private boolean inUnloadQueue = false;
@@ -769,12 +782,14 @@ public final class NewChunkHolder {
// ensure in unload queue
if (!this.inUnloadQueue) {
this.inUnloadQueue = true;
+ this.lastUnloadAdd = new Throwable();
this.scheduler.chunkHolderManager.unloadQueue.addChunk(this.chunkX, this.chunkZ);
}
} else {
// ensure not in unload queue
if (this.inUnloadQueue) {
this.inUnloadQueue = false;
+ this.lastUnloadAdd = null;
this.scheduler.chunkHolderManager.unloadQueue.removeChunk(this.chunkX, this.chunkZ);
}
}