From aff95ee0dced2c5d497ddd7804e82de451c3fc57 Mon Sep 17 00:00:00 2001 From: violetc <58360096+s-yh-china@users.noreply.github.com> Date: Sat, 22 Jul 2023 12:02:21 +0800 Subject: [PATCH] Fix villagers dont release memory --- ...004-Leaves-Server-Config-And-Command.patch | 9 ++++-- ...11-Fix-villagers-dont-release-memory.patch | 31 +++++++++++++++++++ 2 files changed, 38 insertions(+), 2 deletions(-) create mode 100644 patches/server/0111-Fix-villagers-dont-release-memory.patch diff --git a/patches/server/0004-Leaves-Server-Config-And-Command.patch b/patches/server/0004-Leaves-Server-Config-And-Command.patch index 89950454..f9b8676e 100644 --- a/patches/server/0004-Leaves-Server-Config-And-Command.patch +++ b/patches/server/0004-Leaves-Server-Config-And-Command.patch @@ -128,10 +128,10 @@ index 35d2da9d91dcdd89de7c0f4af028fd182376ea8d..d73482fb1e71fe2951e96ae0593de268 .withRequiredArg() diff --git a/src/main/java/top/leavesmc/leaves/LeavesConfig.java b/src/main/java/top/leavesmc/leaves/LeavesConfig.java new file mode 100644 -index 0000000000000000000000000000000000000000..28c18d02a1d04582e6f0badbc9917e6356bf8532 +index 0000000000000000000000000000000000000000..63bbea2329202aef8f0d08c74d950276ccb4344c --- /dev/null +++ b/src/main/java/top/leavesmc/leaves/LeavesConfig.java -@@ -0,0 +1,936 @@ +@@ -0,0 +1,941 @@ +package top.leavesmc.leaves; + +import com.destroystokyo.paper.util.SneakyThrow; @@ -893,6 +893,11 @@ index 0000000000000000000000000000000000000000..28c18d02a1d04582e6f0badbc9917e63 + skipNegligiblePlanarMovementMultiplication = getBoolean("settings.performance.skip-negligible-planar-movement-multiplication", skipNegligiblePlanarMovementMultiplication); + } + ++ public static boolean villagersDontReleaseMemoryFix = false; ++ private static void villagersDontReleaseMemoryFix() { ++ villagersDontReleaseMemoryFix = getBoolean("settings.performance.fix-villagers-dont-release-memory", villagersDontReleaseMemoryFix); ++ } ++ + public static final class WorldConfig { + + public final String worldName; diff --git a/patches/server/0111-Fix-villagers-dont-release-memory.patch b/patches/server/0111-Fix-villagers-dont-release-memory.patch new file mode 100644 index 00000000..7aee8918 --- /dev/null +++ b/patches/server/0111-Fix-villagers-dont-release-memory.patch @@ -0,0 +1,31 @@ +From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001 +From: violetc <58360096+s-yh-china@users.noreply.github.com> +Date: Sat, 22 Jul 2023 12:00:59 +0800 +Subject: [PATCH] Fix villagers dont release memory + + +diff --git a/src/main/java/net/minecraft/world/entity/npc/Villager.java b/src/main/java/net/minecraft/world/entity/npc/Villager.java +index 79bfd7b5da13197c2d3f7dbf9c3154dd783d1ba8..3e36b1f0d8f18de7afe7a1db6cf3a695b7d7a58c 100644 +--- a/src/main/java/net/minecraft/world/entity/npc/Villager.java ++++ b/src/main/java/net/minecraft/world/entity/npc/Villager.java +@@ -1076,4 +1076,20 @@ public class Villager extends AbstractVillager implements ReputationEventHandler + + return optional.isPresent() ? worldTime - (Long) optional.get() < 24000L : false; + } ++ ++ // Leaves start - fixes a memory leak when villagers get moved to another world ++ @Nullable ++ @Override ++ public Entity changeDimension(ServerLevel destination) { ++ if (top.leavesmc.leaves.LeavesConfig.villagersDontReleaseMemoryFix) { ++ this.releaseAllPois(); ++ this.getBrain().eraseMemory(MemoryModuleType.HOME); ++ this.getBrain().eraseMemory(MemoryModuleType.JOB_SITE); ++ this.getBrain().eraseMemory(MemoryModuleType.POTENTIAL_JOB_SITE); ++ this.getBrain().eraseMemory(MemoryModuleType.MEETING_POINT); ++ this.refreshBrain(destination); ++ } ++ return super.changeDimension(destination); ++ } ++ // Leaves end - fixes a memory leak when villagers get moved to another world + }