mirror of
https://github.com/SparklyPower/SparklyPaper.git
synced 2025-12-19 15:09:27 +00:00
210 lines
11 KiB
Diff
210 lines
11 KiB
Diff
From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001
|
|
From: MrPowerGamerBR <git@mrpowergamerbr.com>
|
|
Date: Tue, 21 Nov 2023 16:50:04 -0300
|
|
Subject: [PATCH] Spooky month optimizations
|
|
|
|
The quintessential patch that other performance forks also have for... some reason??? I thought that this optimization was too funny to not do it in SparklyPaper.
|
|
|
|
Caches when Bat's spooky season starts and ends, and when Skeleton and Zombies halloween starts and ends. The epoch is updated every 90 days. If your server is running for 90+ days straight without restarts, congratulations!
|
|
|
|
Avoids unnecessary date checks, even tho that this shouldn't really improve performance that much... unless you have a lot of bats/zombies/skeletons spawning.
|
|
|
|
diff --git a/src/main/java/net/minecraft/server/MinecraftServer.java b/src/main/java/net/minecraft/server/MinecraftServer.java
|
|
index bca2e29e2e2bb4d79e6d3d0eef76a14fcde52022..ae085afa4d532c13a02321407d9f5059e4a3e567 100644
|
|
--- a/src/main/java/net/minecraft/server/MinecraftServer.java
|
|
+++ b/src/main/java/net/minecraft/server/MinecraftServer.java
|
|
@@ -334,7 +334,8 @@ public abstract class MinecraftServer extends ReentrantBlockableEventLoop<TickTa
|
|
public static final long SERVER_INIT = System.nanoTime(); // Paper - Lag compensation
|
|
private List<String> pluginsBlockingSleep = new ArrayList<>(); // Paper - API to allow/disallow tick sleeping
|
|
public final Set<Entity> entitiesWithScheduledTasks = java.util.concurrent.ConcurrentHashMap.newKeySet(); // SparklyPaper - skip EntityScheduler's executeTick checks if there isn't any tasks to be run (concurrent because plugins may schedule tasks async)
|
|
-
|
|
+ public net.sparklypower.sparklypaper.HalloweenManager halloweenManager = new net.sparklypower.sparklypaper.HalloweenManager(); // SparklyPaper - Spooky month optimizations
|
|
+
|
|
public static <S extends MinecraftServer> S spin(Function<Thread, S> serverFactory) {
|
|
AtomicReference<S> atomicreference = new AtomicReference();
|
|
Thread thread = new ca.spottedleaf.moonrise.common.util.TickThread(() -> { // Paper - rewrite chunk system
|
|
diff --git a/src/main/java/net/minecraft/server/dedicated/DedicatedServer.java b/src/main/java/net/minecraft/server/dedicated/DedicatedServer.java
|
|
index bb8975cd3d3b1c57f313ad31b5e767fa93ad8e13..e49e8e98ebbd3c8ba8a784f1626132699209b4e3 100644
|
|
--- a/src/main/java/net/minecraft/server/dedicated/DedicatedServer.java
|
|
+++ b/src/main/java/net/minecraft/server/dedicated/DedicatedServer.java
|
|
@@ -244,6 +244,10 @@ public class DedicatedServer extends MinecraftServer implements ServerInterface
|
|
}
|
|
net.sparklypower.sparklypaper.SparklyPaperCommands.INSTANCE.registerCommands(this);
|
|
// SparklyPaper end
|
|
+ // SparklyPaper start - Spooky month optimizations
|
|
+ halloweenManager.startHalloweenEpochTask();
|
|
+ halloweenManager.waitUntilEpochHasBeenUpdated();
|
|
+ // SparklyPaper end
|
|
com.destroystokyo.paper.VersionHistoryManager.INSTANCE.getClass(); // Paper - load version history now
|
|
|
|
this.setPvpAllowed(dedicatedserverproperties.pvp);
|
|
diff --git a/src/main/java/net/minecraft/world/entity/ambient/Bat.java b/src/main/java/net/minecraft/world/entity/ambient/Bat.java
|
|
index 60c2868f255d372226e0c1389caaa5477bbef41e..64b601a5275374ae8038eaa63f2dddfbb09f593a 100644
|
|
--- a/src/main/java/net/minecraft/world/entity/ambient/Bat.java
|
|
+++ b/src/main/java/net/minecraft/world/entity/ambient/Bat.java
|
|
@@ -232,7 +232,7 @@ public class Bat extends AmbientCreature {
|
|
int i = world.getMaxLocalRawBrightness(pos);
|
|
byte b0 = 4;
|
|
|
|
- if (Bat.isHalloween()) {
|
|
+ if (world.getServer().halloweenManager.isSpookySeason()) { // SparklyPaper - Spooky month optimizations
|
|
b0 = 7;
|
|
} else if (random.nextBoolean()) {
|
|
return false;
|
|
@@ -242,6 +242,8 @@ public class Bat extends AmbientCreature {
|
|
}
|
|
}
|
|
|
|
+ // SparklyPaper - Spooky month optimizations
|
|
+ /*
|
|
private static boolean isHalloween() {
|
|
LocalDate localdate = LocalDate.now();
|
|
int i = localdate.get(ChronoField.DAY_OF_MONTH);
|
|
@@ -249,6 +251,7 @@ public class Bat extends AmbientCreature {
|
|
|
|
return j == 10 && i >= 20 || j == 11 && i <= 3;
|
|
}
|
|
+ */
|
|
|
|
private void setupAnimationStates() {
|
|
if (this.isResting()) {
|
|
diff --git a/src/main/java/net/minecraft/world/entity/monster/AbstractSkeleton.java b/src/main/java/net/minecraft/world/entity/monster/AbstractSkeleton.java
|
|
index 32670a3cb4b54b66d655197e3fde834d2b2b6d34..68818edaf2762c0610377814aa6cb065fe72d290 100644
|
|
--- a/src/main/java/net/minecraft/world/entity/monster/AbstractSkeleton.java
|
|
+++ b/src/main/java/net/minecraft/world/entity/monster/AbstractSkeleton.java
|
|
@@ -159,10 +159,12 @@ public abstract class AbstractSkeleton extends Monster implements RangedAttackMo
|
|
this.setCanPickUpLoot(this.level().paperConfig().entities.behavior.mobsCanAlwaysPickUpLoot.skeletons || randomsource.nextFloat() < 0.55F * difficulty.getSpecialMultiplier()); // Paper - Add world settings for mobs picking up loot
|
|
if (this.getItemBySlot(EquipmentSlot.HEAD).isEmpty()) {
|
|
LocalDate localdate = LocalDate.now();
|
|
- int i = localdate.get(ChronoField.DAY_OF_MONTH);
|
|
- int j = localdate.get(ChronoField.MONTH_OF_YEAR);
|
|
+ // SparklyPaper start - Spooky month optimizations
|
|
+ // int i = localdate.get(ChronoField.DAY_OF_MONTH);
|
|
+ // int j = localdate.get(ChronoField.MONTH_OF_YEAR);
|
|
|
|
- if (j == 10 && i == 31 && randomsource.nextFloat() < 0.25F) {
|
|
+ if (this.getServer().halloweenManager.isHalloween() /* j == 10 && i == 31 */&& randomsource.nextFloat() < 0.25F) {
|
|
+ // SparklyPaper end
|
|
this.setItemSlot(EquipmentSlot.HEAD, new ItemStack(randomsource.nextFloat() < 0.1F ? Blocks.JACK_O_LANTERN : Blocks.CARVED_PUMPKIN));
|
|
this.armorDropChances[EquipmentSlot.HEAD.getIndex()] = 0.0F;
|
|
}
|
|
diff --git a/src/main/java/net/minecraft/world/entity/monster/Zombie.java b/src/main/java/net/minecraft/world/entity/monster/Zombie.java
|
|
index a12461907278cfbfa3b1c0aa74b9f07a31768b8a..558f885fc0d9d1da54bcb9cfc65efb6ceba77fde 100644
|
|
--- a/src/main/java/net/minecraft/world/entity/monster/Zombie.java
|
|
+++ b/src/main/java/net/minecraft/world/entity/monster/Zombie.java
|
|
@@ -563,10 +563,11 @@ public class Zombie extends Monster {
|
|
|
|
if (this.getItemBySlot(EquipmentSlot.HEAD).isEmpty()) {
|
|
LocalDate localdate = LocalDate.now();
|
|
- int i = localdate.get(ChronoField.DAY_OF_MONTH);
|
|
- int j = localdate.get(ChronoField.MONTH_OF_YEAR);
|
|
+ // SparklyPaper start - Spooky month optimizations
|
|
+ // int i = localdate.get(ChronoField.DAY_OF_MONTH);
|
|
+ // int j = localdate.get(ChronoField.MONTH_OF_YEAR);
|
|
|
|
- if (j == 10 && i == 31 && randomsource.nextFloat() < 0.25F) {
|
|
+ if (this.getServer().halloweenManager.isHalloween() /* j == 10 && i == 31 */&& randomsource.nextFloat() < 0.25F) {
|
|
this.setItemSlot(EquipmentSlot.HEAD, new ItemStack(randomsource.nextFloat() < 0.1F ? Blocks.JACK_O_LANTERN : Blocks.CARVED_PUMPKIN));
|
|
this.armorDropChances[EquipmentSlot.HEAD.getIndex()] = 0.0F;
|
|
}
|
|
diff --git a/src/main/kotlin/net/sparklypower/sparklypaper/HalloweenManager.kt b/src/main/kotlin/net/sparklypower/sparklypaper/HalloweenManager.kt
|
|
new file mode 100644
|
|
index 0000000000000000000000000000000000000000..8dd82e727872c0d6c4d0827ac63d5fecb9218c61
|
|
--- /dev/null
|
|
+++ b/src/main/kotlin/net/sparklypower/sparklypaper/HalloweenManager.kt
|
|
@@ -0,0 +1,93 @@
|
|
+package net.sparklypower.sparklypaper
|
|
+
|
|
+import com.mojang.logging.LogUtils
|
|
+import java.time.LocalDateTime
|
|
+import java.time.Month
|
|
+import java.time.ZoneOffset
|
|
+import java.util.concurrent.*
|
|
+
|
|
+class HalloweenManager {
|
|
+ companion object {
|
|
+ private val LOGGER = LogUtils.getLogger()
|
|
+ }
|
|
+ private var spookySeasonStartEpoch = 0L
|
|
+ private var spookySeasonEndEpoch = 0L
|
|
+ private var halloweenStartEpoch = 0L
|
|
+ private var halloweenEndEpoch = 0L
|
|
+ private var executor = Executors.newSingleThreadScheduledExecutor(object: ThreadFactory {
|
|
+ override fun newThread(p0: Runnable): Thread {
|
|
+ val thread = Thread(p0)
|
|
+ thread.name = "halloween-timer-updater"
|
|
+ thread.priority = 1 // Minimum priority
|
|
+ return thread
|
|
+ }
|
|
+ })
|
|
+ private var latch = CountDownLatch(1)
|
|
+
|
|
+ fun startHalloweenEpochTask() {
|
|
+ var isFirst = true
|
|
+ executor.scheduleAtFixedRate({
|
|
+ updateEpoch()
|
|
+ if (isFirst)
|
|
+ latch.countDown()
|
|
+ isFirst = false
|
|
+ }, 0L, 90L, TimeUnit.DAYS) // Every 90 days
|
|
+ }
|
|
+
|
|
+ fun waitUntilEpochHasBeenUpdated() {
|
|
+ latch.await()
|
|
+ }
|
|
+
|
|
+ fun updateEpoch() {
|
|
+ LOGGER.info("Updating Spooky Season and Halloween Time")
|
|
+ this.spookySeasonStartEpoch = getEpochMillisAtDate(20, Month.OCTOBER, false)
|
|
+ this.spookySeasonEndEpoch = getEpochMillisAtDate(3, Month.NOVEMBER, true)
|
|
+ this.halloweenStartEpoch = getEpochMillisAtDate(31, Month.OCTOBER, false)
|
|
+ this.halloweenEndEpoch = getEpochMillisAtDate(31, Month.OCTOBER, true)
|
|
+ LOGGER.info("Updated Spooky Season and Halloween Time!")
|
|
+ }
|
|
+
|
|
+ fun isSpookySeason() = System.currentTimeMillis() in spookySeasonStartEpoch until spookySeasonEndEpoch
|
|
+ fun isHalloween() = System.currentTimeMillis() in halloweenStartEpoch until halloweenEndEpoch
|
|
+
|
|
+ private fun getEpochMillisAtDate(dayOfMonth: Int, month: Month, isEnd: Boolean): Long {
|
|
+ // Get the current year
|
|
+ val currentYear = LocalDateTime.now().year
|
|
+
|
|
+ // Define the target date (20/10/CurrentYear at midnight)
|
|
+ val targetDate = LocalDateTime.of(
|
|
+ currentYear,
|
|
+ month,
|
|
+ dayOfMonth,
|
|
+ if (isEnd)
|
|
+ 23
|
|
+ else
|
|
+ 0,
|
|
+ if (isEnd)
|
|
+ 59
|
|
+ else
|
|
+ 0,
|
|
+ if (isEnd)
|
|
+ 59
|
|
+ else
|
|
+ 0,
|
|
+ if (isEnd)
|
|
+ 999_999_999
|
|
+ else
|
|
+ 0,
|
|
+ )
|
|
+
|
|
+ // Check if the target date is in the past
|
|
+ val now = LocalDateTime.now()
|
|
+ val adjustedDate = if (now.isAfter(targetDate)) {
|
|
+ // If in the past, adjust to the same date in the next year
|
|
+ targetDate.plusYears(1)
|
|
+ } else {
|
|
+ // If in the future or today, use the original target date
|
|
+ targetDate
|
|
+ }
|
|
+
|
|
+ // Convert the adjusted date to epoch time in milliseconds
|
|
+ return adjustedDate.atZone(ZoneOffset.systemDefault()).toInstant().toEpochMilli()
|
|
+ }
|
|
+}
|
|
\ No newline at end of file
|