2021-06-11 14:02:28 +02:00
|
|
|
From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001
|
|
|
|
From: chase <chasewhip20@gmail.com>
|
|
|
|
Date: Wed, 2 Dec 2020 22:43:39 -0800
|
|
|
|
Subject: [PATCH] add per world spawn limits
|
|
|
|
|
|
|
|
Taken from #2982. Credit to Chasewhip8
|
|
|
|
|
|
|
|
diff --git a/src/main/java/com/destroystokyo/paper/PaperWorldConfig.java b/src/main/java/com/destroystokyo/paper/PaperWorldConfig.java
|
2021-08-25 01:45:40 +02:00
|
|
|
index d8c45d689aeb1c5193d71b8f9b7ea85ae78a4206..dbace53ecb13cf372c8ad0dce2af7dcfe16e86d4 100644
|
2021-06-11 14:02:28 +02:00
|
|
|
--- a/src/main/java/com/destroystokyo/paper/PaperWorldConfig.java
|
|
|
|
+++ b/src/main/java/com/destroystokyo/paper/PaperWorldConfig.java
|
2021-07-25 09:00:54 +02:00
|
|
|
@@ -660,6 +660,19 @@ public class PaperWorldConfig {
|
2021-06-11 14:02:28 +02:00
|
|
|
zombieVillagerInfectionChance = getDouble("zombie-villager-infection-chance", zombieVillagerInfectionChance);
|
|
|
|
}
|
|
|
|
|
|
|
|
+ public int spawnLimitMonsters = -1;
|
|
|
|
+ public int spawnLimitAnimals = -1;
|
|
|
|
+ public int spawnLimitWaterAnimals = -1;
|
|
|
|
+ public int spawnLimitWaterAmbient = -1;
|
|
|
|
+ public int spawnLimitAmbient = -1;
|
|
|
|
+ private void perWorldSpawnLimits() {
|
|
|
|
+ spawnLimitMonsters = getInt("spawn-limits.monsters", spawnLimitMonsters);
|
|
|
|
+ spawnLimitAnimals = getInt("spawn-limits.animals", spawnLimitAnimals);
|
|
|
|
+ spawnLimitWaterAnimals = getInt("spawn-limits.water-animals", spawnLimitWaterAnimals);
|
|
|
|
+ spawnLimitWaterAmbient = getInt("spawn-limits.water-ambient", spawnLimitWaterAmbient);
|
|
|
|
+ spawnLimitAmbient = getInt("spawn-limits.ambient", spawnLimitAmbient);
|
|
|
|
+ }
|
|
|
|
+
|
|
|
|
public int lightQueueSize = 20;
|
|
|
|
private void lightQueueSize() {
|
|
|
|
lightQueueSize = getInt("light-queue-size", lightQueueSize);
|
|
|
|
diff --git a/src/main/java/org/bukkit/craftbukkit/CraftWorld.java b/src/main/java/org/bukkit/craftbukkit/CraftWorld.java
|
2021-08-25 01:45:40 +02:00
|
|
|
index 6f0334f5162087eff0c64c9bdd47ff6b34a481b7..9d7fc426710183f12f5a8606bef459040d4b33bc 100644
|
2021-06-11 14:02:28 +02:00
|
|
|
--- a/src/main/java/org/bukkit/craftbukkit/CraftWorld.java
|
|
|
|
+++ b/src/main/java/org/bukkit/craftbukkit/CraftWorld.java
|
2021-07-17 03:48:27 +02:00
|
|
|
@@ -352,6 +352,13 @@ public class CraftWorld implements World {
|
2021-06-11 14:02:28 +02:00
|
|
|
this.generator = gen;
|
|
|
|
|
2021-06-15 06:55:46 +02:00
|
|
|
this.environment = env;
|
2021-06-11 14:02:28 +02:00
|
|
|
+ // Paper start - per world spawn limits
|
|
|
|
+ this.monsterSpawn = this.world.paperConfig.spawnLimitMonsters;
|
|
|
|
+ this.animalSpawn = this.world.paperConfig.spawnLimitAnimals;
|
|
|
|
+ this.waterAnimalSpawn = this.world.paperConfig.spawnLimitWaterAnimals;
|
|
|
|
+ this.waterAmbientSpawn = this.world.paperConfig.spawnLimitWaterAmbient;
|
|
|
|
+ this.ambientSpawn = this.world.paperConfig.spawnLimitAmbient;
|
|
|
|
+ // Paper end
|
|
|
|
}
|
|
|
|
|
|
|
|
@Override
|