2018-11-09 04:43:38 +01:00
|
|
|
From 085ab94bffa4a3c2d94334a64b83e5af05902981 Mon Sep 17 00:00:00 2001
|
2018-07-19 07:25:18 +02:00
|
|
|
From: Aikar <aikar@aikar.co>
|
|
|
|
Date: Thu, 19 Jul 2018 01:23:00 -0400
|
|
|
|
Subject: [PATCH] Don't process despawn if entity is in a chunk scheduled for
|
|
|
|
unload
|
|
|
|
|
|
|
|
This won't happen anyways if the user has
|
|
|
|
"skip ticking for entities in chunks scheduled for unload" turned on,
|
|
|
|
but if they don't, protect from this instant killing the entity to
|
|
|
|
keep it vanilla in behavior
|
|
|
|
|
|
|
|
a player may teleport away, and trigger instant despawn
|
|
|
|
|
|
|
|
diff --git a/src/main/java/net/minecraft/server/EntityInsentient.java b/src/main/java/net/minecraft/server/EntityInsentient.java
|
2018-11-09 04:43:38 +01:00
|
|
|
index 200d46a8a0..db9201d292 100644
|
2018-07-19 07:25:18 +02:00
|
|
|
--- a/src/main/java/net/minecraft/server/EntityInsentient.java
|
|
|
|
+++ b/src/main/java/net/minecraft/server/EntityInsentient.java
|
2018-11-09 04:43:38 +01:00
|
|
|
@@ -634,6 +634,8 @@ public abstract class EntityInsentient extends EntityLiving {
|
2018-07-19 07:25:18 +02:00
|
|
|
if (this.persistent) {
|
|
|
|
this.ticksFarFromPlayer = 0;
|
|
|
|
} else {
|
|
|
|
+ Chunk currentChunk = getChunkAtLocation(); // Paper
|
2018-08-26 20:11:49 +02:00
|
|
|
+ if (currentChunk != null && currentChunk.scheduledForUnload != null) return; // Paper
|
2018-07-19 07:25:18 +02:00
|
|
|
EntityHuman entityhuman = this.world.findNearbyPlayer(this, -1.0D);
|
|
|
|
|
|
|
|
if (entityhuman != null && entityhuman.affectsSpawning) { // Paper - Affects Spawning API
|
|
|
|
--
|
2018-11-09 04:43:38 +01:00
|
|
|
2.19.1
|
2018-07-19 07:25:18 +02:00
|
|
|
|