2020-05-06 11:48:49 +02:00
|
|
|
From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001
|
2020-04-18 22:02:37 +02:00
|
|
|
From: Aikar <aikar@aikar.co>
|
|
|
|
Date: Sat, 18 Apr 2020 15:59:41 -0400
|
|
|
|
Subject: [PATCH] Don't crash if player is attempted to be removed from
|
|
|
|
untracked chunk.
|
|
|
|
|
|
|
|
I suspect it deals with teleporting as it uses players current x/y/z
|
|
|
|
|
|
|
|
diff --git a/src/main/java/net/minecraft/server/ChunkMapDistance.java b/src/main/java/net/minecraft/server/ChunkMapDistance.java
|
2021-02-21 20:45:33 +01:00
|
|
|
index d15bf949671c9a533573278d573376282bfed8c8..275c2b23b4d1ff09ee2b1823d0780700f773659e 100644
|
2020-04-18 22:02:37 +02:00
|
|
|
--- a/src/main/java/net/minecraft/server/ChunkMapDistance.java
|
|
|
|
+++ b/src/main/java/net/minecraft/server/ChunkMapDistance.java
|
2021-02-21 20:45:33 +01:00
|
|
|
@@ -238,8 +238,8 @@ public abstract class ChunkMapDistance {
|
|
|
|
long i = sectionposition.r().pair();
|
2020-04-18 22:02:37 +02:00
|
|
|
ObjectSet<EntityPlayer> objectset = (ObjectSet) this.c.get(i);
|
|
|
|
|
2020-06-10 05:01:47 +02:00
|
|
|
- objectset.remove(entityplayer);
|
|
|
|
- if (objectset.isEmpty()) {
|
|
|
|
+ if (objectset != null) objectset.remove(entityplayer); // Paper - some state corruption happens here, don't crash, clean up gracefully.
|
|
|
|
+ if (objectset == null || objectset.isEmpty()) { // Paper
|
|
|
|
this.c.remove(i);
|
2020-06-26 03:53:21 +02:00
|
|
|
this.f.update(i, Integer.MAX_VALUE, false);
|
|
|
|
this.g.update(i, Integer.MAX_VALUE, false);
|