2021-06-11 14:02:28 +02:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								From: Jason Penilla <11360596+jpenilla@users.noreply.github.com>
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								Date: Thu, 20 Aug 2020 11:20:12 -0700
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								Subject: [PATCH] Add Wandering Trader spawn rate config options
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								Adds config options for modifying the spawn rates of Wandering Traders.
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								These values are all easy to understand and configure after a quick read of this
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								page on the Minecraft wiki: https://minecraft.gamepedia.com/Wandering_Trader#Spawning
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								Usages of the vanilla WanderingTraderSpawnDelay and WanderingTraderSpawnChance values
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								in IWorldServerData are removed as they were only used in certain places, with hardcoded
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								values used in other places.
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								diff --git a/src/main/java/net/minecraft/world/entity/npc/WanderingTraderSpawner.java b/src/main/java/net/minecraft/world/entity/npc/WanderingTraderSpawner.java
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								index 0000000000000000000000000000000000000000..0000000000000000000000000000000000000000 100644
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								--- a/src/main/java/net/minecraft/world/entity/npc/WanderingTraderSpawner.java
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								+++ b/src/main/java/net/minecraft/world/entity/npc/WanderingTraderSpawner.java
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								@@ -0,0 +0,0 @@ public class WanderingTraderSpawner implements CustomSpawner {
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								     public WanderingTraderSpawner(ServerLevelData properties) {
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								         this.serverLevelData = properties;
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								-        this.tickDelay = 1200;
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								-        this.spawnDelay = properties.getWanderingTraderSpawnDelay();
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								-        this.spawnChance = properties.getWanderingTraderSpawnChance();
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								-        if (this.spawnDelay == 0 && this.spawnChance == 0) {
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								-            this.spawnDelay = 24000;
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								-            properties.setWanderingTraderSpawnDelay(this.spawnDelay);
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								-            this.spawnChance = 25;
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								-            properties.setWanderingTraderSpawnChance(this.spawnChance);
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								-        }
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								+        // Paper start
  
						 
					
						
							
								
									
										
										
										
											2021-06-14 09:58:00 -07:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								+        this.tickDelay = Integer.MIN_VALUE;
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								+        //this.spawnDelay = properties.getWanderingTraderSpawnDelay(); // Paper - This value is read from the world file only for the first spawn, after which vanilla uses a hardcoded value
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								+        //this.spawnChance = properties.getWanderingTraderSpawnChance(); // Paper - This value is read from the world file only for the first spawn, after which vanilla uses a hardcoded value
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								+        //if (this.spawnDelay == 0 && this.spawnChance == 0) {
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								+        //    this.spawnDelay = 24000;
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								+        //    properties.setWanderingTraderSpawnDelay(this.spawnDelay);
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								+        //    this.spawnChance = 25;
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								+        //    properties.setWanderingTraderSpawnChance(this.spawnChance);
  
						 
					
						
							
								
									
										
										
										
											2021-06-11 14:02:28 +02:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								+        //}
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								+        // Paper end
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								     }
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								     @Override
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								     public int tick(ServerLevel world, boolean spawnMonsters, boolean spawnAnimals) {
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								+        // Paper start
  
						 
					
						
							
								
									
										
										
										
											2021-06-14 09:58:00 -07:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								+        if (this.tickDelay == Integer.MIN_VALUE) {
  
						 
					
						
							
								
									
										
										
										
											2022-06-09 01:51:45 -07:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								+            this.tickDelay = world.paperConfig().entities.spawning.wanderingTrader.spawnMinuteLength;
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								+            this.spawnDelay = world.paperConfig().entities.spawning.wanderingTrader.spawnDayLength;
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								+            this.spawnChance = world.paperConfig().entities.spawning.wanderingTrader.spawnChanceMin;
  
						 
					
						
							
								
									
										
										
										
											2021-06-11 14:02:28 +02:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								+        }
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								         if (!world.getGameRules().getBoolean(GameRules.RULE_DO_TRADER_SPAWNING)) {
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								             return 0;
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								-        } else if (--this.tickDelay > 0) {
  
						 
					
						
							
								
									
										
										
										
											2021-06-14 09:58:00 -07:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								+        } else if (this.tickDelay - 1 > 0) {
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								+            this.tickDelay = this.tickDelay - 1;
  
						 
					
						
							
								
									
										
										
										
											2021-06-11 14:02:28 +02:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								             return 0;
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								         } else {
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								-            this.tickDelay = 1200;
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								-            this.spawnDelay -= 1200;
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								-            this.serverLevelData.setWanderingTraderSpawnDelay(this.spawnDelay);
  
						 
					
						
							
								
									
										
										
										
											2022-06-09 01:51:45 -07:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								+            this.tickDelay = world.paperConfig().entities.spawning.wanderingTrader.spawnMinuteLength;
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								+            this.spawnDelay = this.spawnDelay - world.paperConfig().entities.spawning.wanderingTrader.spawnMinuteLength;
  
						 
					
						
							
								
									
										
										
										
											2021-06-14 09:58:00 -07:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								+            //this.serverLevelData.setWanderingTraderSpawnDelay(this.spawnDelay); // Paper - We don't need to save this value to disk if it gets set back to a hardcoded value anyways
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								             if (this.spawnDelay > 0) {
							 
						 
					
						
							
								
									
										
										
										
											2021-06-11 14:02:28 +02:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								                 return 0;
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								             } else {
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								-                this.spawnDelay = 24000;
  
						 
					
						
							
								
									
										
										
										
											2022-06-09 01:51:45 -07:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								+                this.spawnDelay = world.paperConfig().entities.spawning.wanderingTrader.spawnDayLength;
  
						 
					
						
							
								
									
										
										
										
											2021-06-11 14:02:28 +02:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								                 if (!world.getGameRules().getBoolean(GameRules.RULE_DOMOBSPAWNING)) {
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                     return 0;
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                 } else {
							 
						 
					
						
							
								
									
										
										
										
											2021-06-14 09:58:00 -07:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                     int i = this.spawnChance;
							 
						 
					
						
							
								
									
										
										
										
											2021-06-11 14:02:28 +02:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								 
							 
						 
					
						
							
								
									
										
										
										
											2021-11-24 17:39:04 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								-                    this.spawnChance = Mth.clamp(this.spawnChance + 25, (int) 25, (int) 75);
  
						 
					
						
							
								
									
										
										
										
											2021-06-11 14:02:28 +02:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								-                    this.serverLevelData.setWanderingTraderSpawnChance(this.spawnChance);
  
						 
					
						
							
								
									
										
										
										
											2022-06-09 01:51:45 -07:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								+                    this.spawnChance = Mth.clamp(i + world.paperConfig().entities.spawning.wanderingTrader.spawnChanceFailureIncrement, world.paperConfig().entities.spawning.wanderingTrader.spawnChanceMin, world.paperConfig().entities.spawning.wanderingTrader.spawnChanceMax);
  
						 
					
						
							
								
									
										
										
										
											2021-06-14 09:58:00 -07:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								+                    //this.serverLevelData.setWanderingTraderSpawnChance(this.spawnChance); // Paper - We don't need to save this value to disk if it gets set back to a hardcoded value anyways
  
						 
					
						
							
								
									
										
										
										
											2021-06-11 14:02:28 +02:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								                     if (this.random.nextInt(100) > i) {
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                         return 0;
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                     } else if (this.spawn(world)) {
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								-                        this.spawnChance = 25;
  
						 
					
						
							
								
									
										
										
										
											2022-06-09 01:51:45 -07:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								+                        this.spawnChance = world.paperConfig().entities.spawning.wanderingTrader.spawnChanceMin;
  
						 
					
						
							
								
									
										
										
										
											2021-06-11 14:02:28 +02:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								+                        // Paper end
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                         return 1;
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                     } else {
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                         return 0;