aboutsummaryrefslogtreecommitdiffhomepage
path: root/patches/server/0838-Configurable-max-block-light-for-monster-spawning.patch
diff options
context:
space:
mode:
authorNassim Jahnke <[email protected]>2021-12-22 12:47:15 +0100
committerGitHub <[email protected]>2021-12-22 12:47:15 +0100
commit10bfb63f6c027158e21ae769270dd22b2abf88d1 (patch)
treede0b36628bdd6b8c8c29a9f11dbbf3a91af2b285 /patches/server/0838-Configurable-max-block-light-for-monster-spawning.patch
parent26fbb02aaee9a00f3fa45edab66e4104f8de13da (diff)
downloadPaper-10bfb63f6c027158e21ae769270dd22b2abf88d1.tar.gz
Paper-10bfb63f6c027158e21ae769270dd22b2abf88d1.zip
Configurable max block light for monster spawning (#7129)
Diffstat (limited to 'patches/server/0838-Configurable-max-block-light-for-monster-spawning.patch')
-rw-r--r--patches/server/0838-Configurable-max-block-light-for-monster-spawning.patch33
1 files changed, 33 insertions, 0 deletions
diff --git a/patches/server/0838-Configurable-max-block-light-for-monster-spawning.patch b/patches/server/0838-Configurable-max-block-light-for-monster-spawning.patch
new file mode 100644
index 0000000000..ce32a15368
--- /dev/null
+++ b/patches/server/0838-Configurable-max-block-light-for-monster-spawning.patch
@@ -0,0 +1,33 @@
+From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001
+From: Nassim Jahnke <[email protected]>
+Date: Thu, 16 Dec 2021 09:40:39 +0100
+Subject: [PATCH] Configurable max block light for monster spawning
+
+
+diff --git a/src/main/java/com/destroystokyo/paper/PaperWorldConfig.java b/src/main/java/com/destroystokyo/paper/PaperWorldConfig.java
+index d71cd626bcbefc576f9c05b8885acc9fb2a33cd5..5a5db15493cd9b83815c36487c2f38cb8ac76f3a 100644
+--- a/src/main/java/com/destroystokyo/paper/PaperWorldConfig.java
++++ b/src/main/java/com/destroystokyo/paper/PaperWorldConfig.java
+@@ -1014,4 +1014,9 @@ public class PaperWorldConfig {
+ Integer rate = table.get(columnKey, rowKey);
+ return rate != null && rate > -1 ? rate : def;
+ }
++
++ public int maxBlockLightForMonsterSpawning = -1;
++ private void minBlockLightForMobSpawning() {
++ this.maxBlockLightForMonsterSpawning = getInt("monster-spawn-max-light-level", maxBlockLightForMonsterSpawning);
++ }
+ }
+diff --git a/src/main/java/net/minecraft/world/entity/monster/Monster.java b/src/main/java/net/minecraft/world/entity/monster/Monster.java
+index 457880c9e894a83d88505cf0b7235df919eea591..1d66588cfe94d190a34dc376b4b5bff9461a3529 100644
+--- a/src/main/java/net/minecraft/world/entity/monster/Monster.java
++++ b/src/main/java/net/minecraft/world/entity/monster/Monster.java
+@@ -90,7 +90,7 @@ public abstract class Monster extends PathfinderMob implements Enemy {
+ public static boolean isDarkEnoughToSpawn(ServerLevelAccessor world, BlockPos pos, Random random) {
+ if (world.getBrightness(LightLayer.SKY, pos) > random.nextInt(32)) {
+ return false;
+- } else if (world.getBrightness(LightLayer.BLOCK, pos) > 0) {
++ } else if (world.getBrightness(LightLayer.BLOCK, pos) > (world.getLevel().paperConfig.maxBlockLightForMonsterSpawning >= 0 ? world.getLevel().paperConfig.maxBlockLightForMonsterSpawning : 0)) { // Paper - configurable max block light level
+ return false;
+ } else {
+ int i = world.getLevel().isThundering() ? world.getMaxLocalRawBrightness(pos, 10) : world.getMaxLocalRawBrightness(pos);