diff --git a/patches/server/0061-Implement-lagging-threshold.patch b/patches/server/0060-Implement-lagging-threshold.patch similarity index 96% rename from patches/server/0061-Implement-lagging-threshold.patch rename to patches/server/0060-Implement-lagging-threshold.patch index 98c46958c..507353ac8 100644 --- a/patches/server/0061-Implement-lagging-threshold.patch +++ b/patches/server/0060-Implement-lagging-threshold.patch @@ -1,4 +1,4 @@ -From e8f673e15dac66aa35d517bfc81a83635e96d6a6 Mon Sep 17 00:00:00 2001 +From cc1a5e544d859ccce9b4462070864188d13997b3 Mon Sep 17 00:00:00 2001 From: William Blake Galbreath Date: Tue, 23 Jul 2019 10:07:16 -0500 Subject: [PATCH] Implement lagging threshold @@ -30,7 +30,7 @@ index c5e89790fc..bfd1a9a809 100644 tickSection = curTime; } diff --git a/src/main/java/net/pl3x/purpur/PurpurConfig.java b/src/main/java/net/pl3x/purpur/PurpurConfig.java -index 4943f48efd..eeb98ed666 100644 +index d8321e8ec3..14450651cb 100644 --- a/src/main/java/net/pl3x/purpur/PurpurConfig.java +++ b/src/main/java/net/pl3x/purpur/PurpurConfig.java @@ -138,9 +138,11 @@ public class PurpurConfig { diff --git a/patches/server/0060-Implement-configurable-villager-brain-ticks.patch b/patches/server/0061-Implement-configurable-villager-brain-ticks.patch similarity index 67% rename from patches/server/0060-Implement-configurable-villager-brain-ticks.patch rename to patches/server/0061-Implement-configurable-villager-brain-ticks.patch index 211dbf089..a6d3575e7 100644 --- a/patches/server/0060-Implement-configurable-villager-brain-ticks.patch +++ b/patches/server/0061-Implement-configurable-villager-brain-ticks.patch @@ -1,15 +1,15 @@ -From d96f2d09d32e6c330b0c7344ee530cc699b81441 Mon Sep 17 00:00:00 2001 +From ba81b317d984abec1c5bbe377c5122b5e594c126 Mon Sep 17 00:00:00 2001 From: William Blake Galbreath Date: Tue, 23 Jul 2019 08:28:21 -0500 Subject: [PATCH] Implement configurable villager brain ticks --- - src/main/java/net/minecraft/server/EntityVillager.java | 3 +++ - src/main/java/net/pl3x/purpur/PurpurConfig.java | 5 +++++ - 2 files changed, 8 insertions(+) + src/main/java/net/minecraft/server/EntityVillager.java | 6 ++++++ + src/main/java/net/pl3x/purpur/PurpurConfig.java | 7 +++++++ + 2 files changed, 13 insertions(+) diff --git a/src/main/java/net/minecraft/server/EntityVillager.java b/src/main/java/net/minecraft/server/EntityVillager.java -index c3bbf49978..afba9c36c9 100644 +index c3bbf49978..53a50b4a40 100644 --- a/src/main/java/net/minecraft/server/EntityVillager.java +++ b/src/main/java/net/minecraft/server/EntityVillager.java @@ -53,6 +53,7 @@ public class EntityVillager extends EntityVillagerAbstract implements Reputation @@ -28,25 +28,30 @@ index c3bbf49978..afba9c36c9 100644 } @Override -@@ -145,6 +147,7 @@ public class EntityVillager extends EntityVillagerAbstract implements Reputation +@@ -145,6 +147,10 @@ public class EntityVillager extends EntityVillagerAbstract implements Reputation @Override protected void mobTick() { this.world.getMethodProfiler().enter("brain"); -+ if ((world.getTime() + brainTickOffset) % net.pl3x.purpur.PurpurConfig.villagerBrainTicks == 0) // Purpur ++ // Purpur start ++ boolean tick = (world.getTime() + brainTickOffset) % net.pl3x.purpur.PurpurConfig.villagerBrainTicks == 0; ++ if (((WorldServer) world).getMinecraftServer().lagging ? tick : net.pl3x.purpur.PurpurConfig.useVillagerBrainTicksOnlyWhenLagging || tick) ++ // Purpur end this.getBehaviorController().a((WorldServer) this.world, this); // CraftBukkit - decompile error this.world.getMethodProfiler().exit(); if (!this.dY() && this.bE > 0) { diff --git a/src/main/java/net/pl3x/purpur/PurpurConfig.java b/src/main/java/net/pl3x/purpur/PurpurConfig.java -index d8321e8ec3..4943f48efd 100644 +index 14450651cb..08475aa6fc 100644 --- a/src/main/java/net/pl3x/purpur/PurpurConfig.java +++ b/src/main/java/net/pl3x/purpur/PurpurConfig.java -@@ -207,6 +207,11 @@ public class PurpurConfig { +@@ -209,6 +209,13 @@ public class PurpurConfig { snowmanPumpkinPutBack = getBoolean("settings.mobs.snow_golem.pumpkin-can-be-added-back", snowmanPumpkinPutBack); } ++ public static boolean useVillagerBrainTicksOnlyWhenLagging = true; + public static int villagerBrainTicks = 20; + private static void villagerSettings() { -+ villagerBrainTicks = getInt("settings.mobs.brain-ticks", villagerBrainTicks); ++ useVillagerBrainTicksOnlyWhenLagging = getBoolean("settings.mobs.villager.use-brain-ticks-only-when-lagging", useVillagerBrainTicksOnlyWhenLagging); ++ villagerBrainTicks = getInt("settings.mobs.villager.brain-ticks", villagerBrainTicks); + } + public static boolean largeEnderChests = true;