2016-04-15 03:03:57 +02:00
|
|
|
From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001
|
|
|
|
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 03:31:12 +02:00
|
|
|
diff --git a/src/main/java/net/minecraft/server/Chunk.java b/src/main/java/net/minecraft/server/Chunk.java
|
2018-07-10 07:06:09 +02:00
|
|
|
index e07ef14ed..aca1457b0 100644
|
2016-04-16 03:31:12 +02:00
|
|
|
--- a/src/main/java/net/minecraft/server/Chunk.java
|
|
|
|
+++ b/src/main/java/net/minecraft/server/Chunk.java
|
|
|
|
@@ -0,0 +0,0 @@ public class Chunk {
|
|
|
|
i = this.entitySlices.length - 1;
|
|
|
|
}
|
|
|
|
|
|
|
|
- this.entitySlices[i].remove(entity);
|
|
|
|
+ if (!this.entitySlices[i].remove(entity)) { return; } // Paper
|
|
|
|
// Paper start - update counts
|
|
|
|
if (entity instanceof EntityItem) {
|
|
|
|
itemCounts[i]--;
|
2016-04-15 03:03:57 +02:00
|
|
|
diff --git a/src/main/java/net/minecraft/server/SpawnerCreature.java b/src/main/java/net/minecraft/server/SpawnerCreature.java
|
2018-07-10 07:06:09 +02:00
|
|
|
index 45a83ae99..ed22607d9 100644
|
2016-04-15 03:03:57 +02:00
|
|
|
--- a/src/main/java/net/minecraft/server/SpawnerCreature.java
|
|
|
|
+++ b/src/main/java/net/minecraft/server/SpawnerCreature.java
|
|
|
|
@@ -0,0 +0,0 @@ public final class SpawnerCreature {
|
|
|
|
// 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 07:06:09 +02:00
|
|
|
+ int sum = 0;
|
|
|
|
+ for (Chunk c : server.getChunkProviderServer().chunks.values()) {
|
|
|
|
+ sum += c.entityCount.get(oClass);
|
|
|
|
+ }
|
|
|
|
+ return sum;
|
2016-04-15 03:03:57 +02:00
|
|
|
+ }
|
|
|
|
+ // Paper end
|
|
|
|
int i = 0;
|
|
|
|
Iterator<Long> it = this.b.iterator();
|
|
|
|
while ( it.hasNext() )
|
|
|
|
@@ -0,0 +0,0 @@ public final class SpawnerCreature {
|
|
|
|
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();
|
|
|
|
|
|
|
|
--
|