From 9669092af295a7465ccd9ee80e9b9c82c9d76de9 Mon Sep 17 00:00:00 2001 From: Markus Bordihn Date: Tue, 15 Oct 2024 13:42:09 +0200 Subject: [PATCH] Fixed #72 and #75 by moving the `removeWhenFarAway` check to a later stage to exclude the check for the Endergetic Expansion mod. Smaller code optimizations and performance improvements. --- CHANGELOG.md | 6 ++ .../CoreConstants.java | 4 + .../entity/CoreEntityManager.java | 13 ++- .../message/WarnMessages.java | 6 ++ .../player/PlayerPositionManager.java | 14 +-- .../server/ServerManager.java | 27 ++---- .../viewarea/ViewArea.java | 36 +++---- gradle.properties | 2 +- .../spawn/SpawnManager.java | 95 ++++++++++--------- 9 files changed, 101 insertions(+), 102 deletions(-) diff --git a/CHANGELOG.md b/CHANGELOG.md index 76172b7f..b1b37550 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -5,6 +5,12 @@ This change log includes the summarized changes. For the full changelog, please go to the [GitHub History][history] instead. +### v11.3.0 + +- Fixed #72 and #75 by moving the `removeWhenFarAway` check to a later stage to exclude the check + for the Endergetic Expansion mod. +- Smaller code optimizations and performance improvements. + ### v11.2.0 - Fixed #73 by ignoring corpse entities. diff --git a/core/src/main/java/de/markusbordihn/adaptiveperformancetweakscore/CoreConstants.java b/core/src/main/java/de/markusbordihn/adaptiveperformancetweakscore/CoreConstants.java index 5888816e..a04b6b50 100644 --- a/core/src/main/java/de/markusbordihn/adaptiveperformancetweakscore/CoreConstants.java +++ b/core/src/main/java/de/markusbordihn/adaptiveperformancetweakscore/CoreConstants.java @@ -80,6 +80,10 @@ public final class CoreConstants { public static final String EASY_NPC_MOD = "easy_npc"; public static final String EASY_NPC_NAME = "Easy NPC"; public static final boolean EASY_NPC_LOADED = ModList.get().isLoaded(EASY_NPC_MOD); + public static final String THE_ENDERGETIC_EXPANSION_MOD = "endergetic"; + public static final String THE_ENDERGETIC_EXPANSION_NAME = "The Endergetic Expansion"; + public static final boolean THE_ENDERGETIC_EXPANSION_LOADED = + ModList.get().isLoaded(THE_ENDERGETIC_EXPANSION_MOD); public static final String FISH_OF_THIEVES_MOD = "fishofthieves"; public static final String FISH_OF_THIEVES_NAME = "Fish's Undead Rising"; public static final boolean FISH_OF_THIEVES_LOADED = ModList.get().isLoaded(FISH_OF_THIEVES_MOD); diff --git a/core/src/main/java/de/markusbordihn/adaptiveperformancetweakscore/entity/CoreEntityManager.java b/core/src/main/java/de/markusbordihn/adaptiveperformancetweakscore/entity/CoreEntityManager.java index b4c283b4..7ab1926f 100644 --- a/core/src/main/java/de/markusbordihn/adaptiveperformancetweakscore/entity/CoreEntityManager.java +++ b/core/src/main/java/de/markusbordihn/adaptiveperformancetweakscore/entity/CoreEntityManager.java @@ -425,10 +425,7 @@ public static boolean isRelevantEntity(Entity entity) { || (entity instanceof TamableAnimal tamableAnimal && (tamableAnimal.getOwner() != null || tamableAnimal.getOwnerUUID() != null)) || (entity instanceof Mob mob - && (mob.isLeashed() - || mob.isPersistenceRequired() - || mob.requiresCustomPersistence() - || !mob.removeWhenFarAway(512))) + && (mob.isLeashed() || mob.isPersistenceRequired() || mob.requiresCustomPersistence())) || (entity instanceof Bee bee && bee.hasHive()) || entity.hasCustomName()); } @@ -502,6 +499,14 @@ public static boolean isRelevantEntity(Entity entity, String entityName) { return false; } + // Disable specific checks for mods which accessing chunk data during entity spawn / despawn. + if (!(CoreConstants.THE_ENDERGETIC_EXPANSION_LOADED + && entityName.startsWith(CoreConstants.THE_ENDERGETIC_EXPANSION_MOD)) + && entity instanceof Mob mob + && !mob.removeWhenFarAway(512)) { + return false; + } + // Checking entity NBT data to catch custom entities which are not extending the right classes // or using some custom definitions which could not be easily checked. CompoundTag compoundTag = entity.getPersistentData(); diff --git a/core/src/main/java/de/markusbordihn/adaptiveperformancetweakscore/message/WarnMessages.java b/core/src/main/java/de/markusbordihn/adaptiveperformancetweakscore/message/WarnMessages.java index 590810c8..ec84e832 100644 --- a/core/src/main/java/de/markusbordihn/adaptiveperformancetweakscore/message/WarnMessages.java +++ b/core/src/main/java/de/markusbordihn/adaptiveperformancetweakscore/message/WarnMessages.java @@ -43,6 +43,12 @@ public static String chunkPregeneratorModWarning(String modName) { modName, modName); } + public static String knownIssuesGeneralModWarning(String modName) { + return String.format( + "⚠ There are known issues with the %s mod, please report any related issues to the %s mod author first!", + modName, modName); + } + public static String knownIssuesSpawnModWarning(String modName) { return String.format( "⚠ The %s mod implements their own spawn handling, please report any spawn related issue to the %s mod author!", diff --git a/core/src/main/java/de/markusbordihn/adaptiveperformancetweakscore/player/PlayerPositionManager.java b/core/src/main/java/de/markusbordihn/adaptiveperformancetweakscore/player/PlayerPositionManager.java index 0f51e17e..903af9ea 100644 --- a/core/src/main/java/de/markusbordihn/adaptiveperformancetweakscore/player/PlayerPositionManager.java +++ b/core/src/main/java/de/markusbordihn/adaptiveperformancetweakscore/player/PlayerPositionManager.java @@ -81,22 +81,14 @@ private static void updatePlayerPositions() { } PlayerList playerList = minecraftServer.getPlayerList(); - if (playerList == null) { + if (playerList == null || playerList.getPlayerCount() == 0) { + playerPositionMap.clear(); return; } - int numberOfPlayers = playerList.getPlayerCount(); - if (numberOfPlayers == 0) { - if (!playerPositionMap.isEmpty()) { - playerPositionMap = new ConcurrentHashMap<>(); - } - return; - } - - List serverPlayerList = playerList.getPlayers(); int viewDistance = playerList.getViewDistance(); int simulationDistance = playerList.getSimulationDistance(); - for (ServerPlayer player : serverPlayerList) { + for (ServerPlayer player : playerList.getPlayers()) { if (player.isAlive() && !player.hasDisconnected()) { updatePlayerPosition(player, viewDistance, simulationDistance); } diff --git a/core/src/main/java/de/markusbordihn/adaptiveperformancetweakscore/server/ServerManager.java b/core/src/main/java/de/markusbordihn/adaptiveperformancetweakscore/server/ServerManager.java index 7440861b..9668ef5b 100644 --- a/core/src/main/java/de/markusbordihn/adaptiveperformancetweakscore/server/ServerManager.java +++ b/core/src/main/java/de/markusbordihn/adaptiveperformancetweakscore/server/ServerManager.java @@ -155,10 +155,9 @@ public static long[] getTickTime(ResourceKey level) { public static double getAverageTickTime(ServerLevel serverLevel) { long[] tickTimes = getTickTime(serverLevel.dimension()); - if (tickTimes != null) { - return Arrays.stream(tickTimes).average().orElse(Double.NaN) / 1000000; - } - return 0; + return (tickTimes != null) + ? Arrays.stream(tickTimes).average().orElse(Double.NaN) / 1000000 + : 0; } public static float getAverageTickTime() { @@ -185,19 +184,13 @@ private static void updateGameDifficulty(Difficulty difficulty) { return; } gameDifficulty = difficulty; - switch (difficulty) { - case EASY: - gameDifficultyFactor = gameDifficultyFactorEasy; - break; - case PEACEFUL: - gameDifficultyFactor = gameDifficultyFactorPeaceful; - break; - case HARD: - gameDifficultyFactor = gameDifficultyFactorHard; - break; - default: - gameDifficultyFactor = gameDifficultyFactorNormal; - } + gameDifficultyFactor = + switch (difficulty) { + case EASY -> gameDifficultyFactorEasy; + case PEACEFUL -> gameDifficultyFactorPeaceful; + case HARD -> gameDifficultyFactorHard; + default -> gameDifficultyFactorNormal; + }; log.info( "{} Game difficulty is set to {} with a {} factor.", Constants.LOG_PREFIX, diff --git a/core/src/main/java/de/markusbordihn/adaptiveperformancetweakscore/viewarea/ViewArea.java b/core/src/main/java/de/markusbordihn/adaptiveperformancetweakscore/viewarea/ViewArea.java index 304db6ec..c8e70339 100644 --- a/core/src/main/java/de/markusbordihn/adaptiveperformancetweakscore/viewarea/ViewArea.java +++ b/core/src/main/java/de/markusbordihn/adaptiveperformancetweakscore/viewarea/ViewArea.java @@ -103,23 +103,16 @@ public boolean update(int posX, int posY, int posZ, int viewAreaDistance, String return false; } - // Update position for change detection and debugging purpose. + // Update position and level for change detection and better view area calculation. this.posX = posX; this.posY = posY; this.posZ = posZ; - - // Update level for better view area calculation. this.levelName = levelName; boolean isNether = levelName.equals(NETHER); boolean isTheEnd = levelName.equals(THE_END); - // Limit max view area distance to consider mods which changes these factors. - this.viewAreaDistance = viewAreaDistance; - if (viewAreaDistance > MAX_VIEW_AREA_DISTANCE) { - viewAreaDistance = MAX_VIEW_AREA_DISTANCE; - } - - // Expand view area distance for Nether and The End. + // Limit max view area distance and expand for Nether and The End. + this.viewAreaDistance = Math.min(viewAreaDistance, MAX_VIEW_AREA_DISTANCE); if (isNether) { viewAreaDistance = (int) (viewAreaDistance * NETHER_EXPAND_FACTOR); } else if (isTheEnd) { @@ -127,23 +120,16 @@ public boolean update(int posX, int posY, int posZ, int viewAreaDistance, String } this.blocksViewDistance = viewAreaDistance; - // Simple calculation for X + // Simple calculation for X, Y, and Z this.startX = posX - viewAreaDistance; this.stopX = posX + viewAreaDistance; - - // Simple calculation for Y - if (this.levelName.equals(NETHER)) { - this.startY = Math.max(posY - viewAreaDistance, MIN_BUILD_HEIGHT); - this.stopY = Math.min(posY + viewAreaDistance, MAX_BUILD_HEIGHT_NETHER); - } else if (this.levelName.equals(THE_END)) { - this.startY = Math.max(posY - viewAreaDistance, MIN_BUILD_HEIGHT); - this.stopY = Math.min(posY + viewAreaDistance, MAX_BUILD_HEIGHT_THE_END); - } else { - this.startY = Math.max(posY - viewAreaDistance, MIN_BUILD_HEIGHT); - this.stopY = Math.min(posY + viewAreaDistance, MAX_BUILD_HEIGHT); - } - - // Simple calculation for Z + this.startY = Math.max(posY - viewAreaDistance, MIN_BUILD_HEIGHT); + this.stopY = + Math.min( + posY + viewAreaDistance, + isNether + ? MAX_BUILD_HEIGHT_NETHER + : isTheEnd ? MAX_BUILD_HEIGHT_THE_END : MAX_BUILD_HEIGHT); this.startZ = posZ - viewAreaDistance; this.stopZ = posZ + viewAreaDistance; diff --git a/gradle.properties b/gradle.properties index 7912c3a0..3ba47d6d 100644 --- a/gradle.properties +++ b/gradle.properties @@ -3,7 +3,7 @@ org.gradle.jvmargs=-Xmx3G org.gradle.daemon=false # Project -version=11.2.0 +version=11.3.0 # Mod mod_author=Markus Bordihn vendor_name=markusbordihn diff --git a/spawn/src/main/java/de/markusbordihn/adaptiveperformancetweaksspawn/spawn/SpawnManager.java b/spawn/src/main/java/de/markusbordihn/adaptiveperformancetweaksspawn/spawn/SpawnManager.java index 8624648a..ab469d6b 100644 --- a/spawn/src/main/java/de/markusbordihn/adaptiveperformancetweaksspawn/spawn/SpawnManager.java +++ b/spawn/src/main/java/de/markusbordihn/adaptiveperformancetweaksspawn/spawn/SpawnManager.java @@ -106,47 +106,7 @@ public static void handleServerAboutToStartEvent(ServerAboutToStartEvent event) spawnLimitationMaxMobsPerServer = COMMON.spawnLimitationMaxMobsPerServer.get(); } - @SubscribeEvent - public static void handleServerStarting(ServerStartingEvent event) { - if (!allowList.isEmpty()) { - log.info("{} Spawn allow list: {}", Constants.LOG_PREFIX, allowList); - } - if (!denyList.isEmpty()) { - log.info("{} Spawn deny list: {}", Constants.LOG_PREFIX, denyList); - } - if (!ignoreDimensionList.isEmpty()) { - log.info("{} Ignore dimension list: {}", Constants.LOG_PREFIX, ignoreDimensionList); - } - if (Boolean.TRUE.equals(COMMON.spawnAggressiveMode.get())) { - log.warn("Enable more aggressive spawn optimizations!"); - } else { - log.info( - "If you want to use a more aggressive spawn optimization, please set 'spawnAggressiveMode' to 'true'"); - } - if (Boolean.FALSE.equals(COMMON.viewAreaEnabled.get())) { - log.info("Disable view area optimizations!"); - } - if (spawnLimitationEnabled) { - if (spawnLimitationLimiter > 0) { - log.info( - "{} ✓ Enable limiter and block randomly every {} mob from spawning ...", - Constants.LOG_PREFIX, - spawnLimitationLimiter); - } - if (spawnLimitationMaxMobsPerPlayer > 0) { - log.info( - "{} ✓ Enable spawn rate control with max {} per player ...", - Constants.LOG_PREFIX, - spawnLimitationMaxMobsPerPlayer); - } - if (spawnLimitationMaxMobsPerServer > 0) { - log.info( - "{} ✓ Enable spawn rate control with max {} per server ...", - Constants.LOG_PREFIX, - spawnLimitationMaxMobsPerServer); - } - } - + private static void showModSpecificWarnings() { // Added warning for chunk optimization Mods if (CoreConstants.CHUNK_PREGEN_LOADED) { log.warn(() -> WarnMessages.chunkPregeneratorModWarning(CoreConstants.CHUNK_PREGEN_NAME)); @@ -171,6 +131,12 @@ public static void handleServerStarting(ServerStartingEvent event) { WarnMessages.conflictingFeaturesModWarning( CoreConstants.INCONTROL_NAME, "controls the mob spawns and entity spawns")); } + if (CoreConstants.THE_ENDERGETIC_EXPANSION_LOADED) { + log.warn( + () -> + WarnMessages.knownIssuesGeneralModWarning( + CoreConstants.THE_ENDERGETIC_EXPANSION_NAME)); + } // Disabled optimization warning for specific Mods if (CoreConstants.CREATE_LOADED) { @@ -183,9 +149,6 @@ public static void handleServerStarting(ServerStartingEvent event) { if (CoreConstants.BOTANIA_LOADED) { log.warn(() -> WarnMessages.disabledOptimizationModWarning(CoreConstants.BOTANIA_NAME)); } - if (CoreConstants.CREATE_LOADED) { - log.warn(() -> WarnMessages.disabledOptimizationModWarning(CoreConstants.CREATE_NAME)); - } if (CoreConstants.INDUSTRIAL_FOREGOING_LOADED) { log.warn( () -> @@ -216,6 +179,50 @@ public static void handleServerStarting(ServerStartingEvent event) { } } + @SubscribeEvent + public static void handleServerStarting(ServerStartingEvent event) { + if (!allowList.isEmpty()) { + log.info("{} Spawn allow list: {}", Constants.LOG_PREFIX, allowList); + } + if (!denyList.isEmpty()) { + log.info("{} Spawn deny list: {}", Constants.LOG_PREFIX, denyList); + } + if (!ignoreDimensionList.isEmpty()) { + log.info("{} Ignore dimension list: {}", Constants.LOG_PREFIX, ignoreDimensionList); + } + if (Boolean.TRUE.equals(COMMON.spawnAggressiveMode.get())) { + log.warn("Enable more aggressive spawn optimizations!"); + } else { + log.info( + "If you want to use a more aggressive spawn optimization, please set 'spawnAggressiveMode' to 'true'"); + } + if (Boolean.FALSE.equals(COMMON.viewAreaEnabled.get())) { + log.info("Disable view area optimizations!"); + } + if (spawnLimitationEnabled) { + if (spawnLimitationLimiter > 0) { + log.info( + "{} ✓ Enable limiter and block randomly every {} mob from spawning ...", + Constants.LOG_PREFIX, + spawnLimitationLimiter); + } + if (spawnLimitationMaxMobsPerPlayer > 0) { + log.info( + "{} ✓ Enable spawn rate control with max {} per player ...", + Constants.LOG_PREFIX, + spawnLimitationMaxMobsPerPlayer); + } + if (spawnLimitationMaxMobsPerServer > 0) { + log.info( + "{} ✓ Enable spawn rate control with max {} per server ...", + Constants.LOG_PREFIX, + spawnLimitationMaxMobsPerServer); + } + } + + showModSpecificWarnings(); + } + @SubscribeEvent public static void handleServerStarted(ServerStartedEvent event) { serverStarted = true;