2018-07-15 06:44:37 +00:00
|
|
|
From f7b327727e2ac3ad221592ae2b97c64d9297c702 Mon Sep 17 00:00:00 2001
|
2016-04-15 01:03:57 +00:00
|
|
|
From: Aikar <aikar@aikar.co>
|
|
|
|
Date: Thu, 14 Apr 2016 21:01:39 -0400
|
|
|
|
Subject: [PATCH] Fix Bugs with Spigot Mob Spawn Logic
|
|
|
|
|
|
|
|
Spigot drastically altered vanilla mob spawn logic and caused a few issues.
|
|
|
|
1) Used only spawnable chunks vs entire world for entity counting, resulting in ignoring
|
|
|
|
other entities in the world, and causing the world to go over its intended limit.
|
|
|
|
|
|
|
|
Specially with servers using smaller mob spawn ranges than view distance, as well as affects spawning API
|
|
|
|
|
|
|
|
2) Spigot was using 16x16 division instead of vanilla 17x17 division.
|
|
|
|
|
|
|
|
This patch returns mob counting to use all loaded chunks, and 17x17 division.
|
|
|
|
|
2016-04-16 01:31:12 +00:00
|
|
|
diff --git a/src/main/java/net/minecraft/server/Chunk.java b/src/main/java/net/minecraft/server/Chunk.java
|
2018-07-15 06:44:37 +00:00
|
|
|
index da7b59434..1157bc7eb 100644
|
2016-04-16 01:31:12 +00:00
|
|
|
--- a/src/main/java/net/minecraft/server/Chunk.java
|
|
|
|
+++ b/src/main/java/net/minecraft/server/Chunk.java
|
2018-07-15 06:44:37 +00:00
|
|
|
@@ -714,8 +714,8 @@ public class Chunk {
|
2016-04-16 01:31:12 +00:00
|
|
|
i = this.entitySlices.length - 1;
|
|
|
|
}
|
|
|
|
|
|
|
|
- this.entitySlices[i].remove(entity);
|
2018-07-15 06:44:37 +00:00
|
|
|
// Paper start
|
|
|
|
+ if (!this.entitySlices[i].remove(entity)) { return; }
|
|
|
|
entity.setCurrentChunk(null);
|
|
|
|
entityCounts.decrement(entity.entityKeyString);
|
2016-04-16 01:31:12 +00:00
|
|
|
if (entity instanceof EntityItem) {
|
2016-04-15 01:03:57 +00:00
|
|
|
diff --git a/src/main/java/net/minecraft/server/SpawnerCreature.java b/src/main/java/net/minecraft/server/SpawnerCreature.java
|
2018-07-10 05:06:09 +00:00
|
|
|
index 45a83ae99..ed22607d9 100644
|
2016-04-15 01:03:57 +00:00
|
|
|
--- a/src/main/java/net/minecraft/server/SpawnerCreature.java
|
|
|
|
+++ b/src/main/java/net/minecraft/server/SpawnerCreature.java
|
2016-07-15 22:36:53 +00:00
|
|
|
@@ -23,6 +23,15 @@ public final class SpawnerCreature {
|
2016-04-15 01:03:57 +00:00
|
|
|
// Spigot start - get entity count only from chunks being processed in b
|
|
|
|
private int getEntityCount(WorldServer server, Class oClass)
|
|
|
|
{
|
|
|
|
+ // Paper start - use entire world, not just active chunks. Spigot broke vanilla expectations.
|
|
|
|
+ if (true) {
|
2018-07-10 05:06:09 +00:00
|
|
|
+ int sum = 0;
|
|
|
|
+ for (Chunk c : server.getChunkProviderServer().chunks.values()) {
|
|
|
|
+ sum += c.entityCount.get(oClass);
|
|
|
|
+ }
|
|
|
|
+ return sum;
|
2016-04-15 01:03:57 +00:00
|
|
|
+ }
|
|
|
|
+ // Paper end
|
|
|
|
int i = 0;
|
|
|
|
Iterator<Long> it = this.b.iterator();
|
|
|
|
while ( it.hasNext() )
|
2016-11-17 02:23:38 +00:00
|
|
|
@@ -126,7 +135,7 @@ public final class SpawnerCreature {
|
2016-04-15 01:03:57 +00:00
|
|
|
int l1 = limit * i / a; // CraftBukkit - use per-world limits
|
|
|
|
*/ // Paper end
|
|
|
|
|
|
|
|
- if ((mobcnt = getEntityCount(worldserver, enumcreaturetype.a())) <= limit * i / 256) {
|
|
|
|
+ if ((mobcnt = getEntityCount(worldserver, enumcreaturetype.a())) <= limit * i / 289) { // Paper - use 17x17 like vanilla (a at top of file)
|
|
|
|
BlockPosition.MutableBlockPosition blockposition_mutableblockposition = new BlockPosition.MutableBlockPosition();
|
|
|
|
Iterator iterator1 = this.b.iterator();
|
|
|
|
|
|
|
|
--
|
2018-07-04 07:55:24 +00:00
|
|
|
2.18.0
|
2016-04-15 01:03:57 +00:00
|
|
|
|