mirror of
https://github.com/PaperMC/Paper.git
synced 2025-01-01 17:01:56 +01:00
Fix bug with entities not being added from loaded chunks
No entities were lost in this bug, just we were triggering the add entities before they were loaded due to an inconsistent order of putting chunk into chunkmap. Any entity that appeared to be gone on the last build will now be back.
This commit is contained in:
parent
1c52c3a29c
commit
430513974f
1 changed files with 17 additions and 3 deletions
|
@ -14,7 +14,7 @@ Moves Entity Add to World to be done anytime a chunk is
|
||||||
registered to the Chunk Map, and ignore other calls.
|
registered to the Chunk Map, and ignore other calls.
|
||||||
|
|
||||||
diff --git a/src/main/java/net/minecraft/server/Chunk.java b/src/main/java/net/minecraft/server/Chunk.java
|
diff --git a/src/main/java/net/minecraft/server/Chunk.java b/src/main/java/net/minecraft/server/Chunk.java
|
||||||
index 4e32ae7db..f0098e910 100644
|
index 4e32ae7db6..f0098e910a 100644
|
||||||
--- a/src/main/java/net/minecraft/server/Chunk.java
|
--- a/src/main/java/net/minecraft/server/Chunk.java
|
||||||
+++ b/src/main/java/net/minecraft/server/Chunk.java
|
+++ b/src/main/java/net/minecraft/server/Chunk.java
|
||||||
@@ -0,0 +0,0 @@ public class Chunk implements IChunkAccess {
|
@@ -0,0 +0,0 @@ public class Chunk implements IChunkAccess {
|
||||||
|
@ -28,7 +28,7 @@ index 4e32ae7db..f0098e910 100644
|
||||||
this.world.b(this.tileEntities.values());
|
this.world.b(this.tileEntities.values());
|
||||||
List[] aentityslice = this.entitySlices; // Spigot
|
List[] aentityslice = this.entitySlices; // Spigot
|
||||||
diff --git a/src/main/java/net/minecraft/server/ChunkMap.java b/src/main/java/net/minecraft/server/ChunkMap.java
|
diff --git a/src/main/java/net/minecraft/server/ChunkMap.java b/src/main/java/net/minecraft/server/ChunkMap.java
|
||||||
index 5757aa80f..c6cedba96 100644
|
index 5757aa80f3..c6cedba96e 100644
|
||||||
--- a/src/main/java/net/minecraft/server/ChunkMap.java
|
--- a/src/main/java/net/minecraft/server/ChunkMap.java
|
||||||
+++ b/src/main/java/net/minecraft/server/ChunkMap.java
|
+++ b/src/main/java/net/minecraft/server/ChunkMap.java
|
||||||
@@ -0,0 +0,0 @@ public class ChunkMap extends Long2ObjectOpenHashMap<Chunk> {
|
@@ -0,0 +0,0 @@ public class ChunkMap extends Long2ObjectOpenHashMap<Chunk> {
|
||||||
|
@ -39,8 +39,22 @@ index 5757aa80f..c6cedba96 100644
|
||||||
|
|
||||||
org.bukkit.Server server = chunk.world.getServer();
|
org.bukkit.Server server = chunk.world.getServer();
|
||||||
if (server != null) {
|
if (server != null) {
|
||||||
|
diff --git a/src/main/java/net/minecraft/server/ChunkRegionLoader.java b/src/main/java/net/minecraft/server/ChunkRegionLoader.java
|
||||||
|
index bd52bf6561..e27e952a1b 100644
|
||||||
|
--- a/src/main/java/net/minecraft/server/ChunkRegionLoader.java
|
||||||
|
+++ b/src/main/java/net/minecraft/server/ChunkRegionLoader.java
|
||||||
|
@@ -0,0 +0,0 @@ public class ChunkRegionLoader implements IChunkLoader, IAsyncChunkSaver {
|
||||||
|
if (data != null) {
|
||||||
|
Chunk chunk = (Chunk) data[0];
|
||||||
|
NBTTagCompound nbttagcompound = (NBTTagCompound) data[1];
|
||||||
|
- consumer.accept(chunk);
|
||||||
|
this.loadEntities(nbttagcompound.getCompound("Level"), chunk);
|
||||||
|
+ consumer.accept(chunk); // Paper - call AFTER entities are loaded
|
||||||
|
return chunk;
|
||||||
|
}
|
||||||
|
|
||||||
diff --git a/src/main/java/net/minecraft/server/World.java b/src/main/java/net/minecraft/server/World.java
|
diff --git a/src/main/java/net/minecraft/server/World.java b/src/main/java/net/minecraft/server/World.java
|
||||||
index ece187129..4fc3c2c35 100644
|
index ece1871294..4fc3c2c354 100644
|
||||||
--- a/src/main/java/net/minecraft/server/World.java
|
--- a/src/main/java/net/minecraft/server/World.java
|
||||||
+++ b/src/main/java/net/minecraft/server/World.java
|
+++ b/src/main/java/net/minecraft/server/World.java
|
||||||
@@ -0,0 +0,0 @@ public abstract class World implements GeneratorAccess, IIBlockAccess, AutoClose
|
@@ -0,0 +0,0 @@ public abstract class World implements GeneratorAccess, IIBlockAccess, AutoClose
|
||||||
|
|
Loading…
Reference in a new issue