aboutsummaryrefslogtreecommitdiffhomepage
path: root/patches/server/0811-Add-Player-Warden-Warning-API.patch
diff options
context:
space:
mode:
Diffstat (limited to 'patches/server/0811-Add-Player-Warden-Warning-API.patch')
-rw-r--r--patches/server/0811-Add-Player-Warden-Warning-API.patch57
1 files changed, 57 insertions, 0 deletions
diff --git a/patches/server/0811-Add-Player-Warden-Warning-API.patch b/patches/server/0811-Add-Player-Warden-Warning-API.patch
new file mode 100644
index 0000000000..e38acd3ff2
--- /dev/null
+++ b/patches/server/0811-Add-Player-Warden-Warning-API.patch
@@ -0,0 +1,57 @@
+From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001
+From: dawon <[email protected]>
+Date: Sat, 15 Oct 2022 00:46:57 +0200
+Subject: [PATCH] Add Player Warden Warning API
+
+== AT ==
+public net.minecraft.server.level.ServerPlayer wardenSpawnTracker
+public net.minecraft.world.entity.monster.warden.WardenSpawnTracker ticksSinceLastWarning
+public net.minecraft.world.entity.monster.warden.WardenSpawnTracker cooldownTicks
+public net.minecraft.world.entity.monster.warden.WardenSpawnTracker increaseWarningLevel()V
+
+diff --git a/src/main/java/org/bukkit/craftbukkit/entity/CraftPlayer.java b/src/main/java/org/bukkit/craftbukkit/entity/CraftPlayer.java
+index fb68934b8210bae3de5260d72d1a299c1f941044..fc47eb2de7e8d39b3a053e5458529267cc86408d 100644
+--- a/src/main/java/org/bukkit/craftbukkit/entity/CraftPlayer.java
++++ b/src/main/java/org/bukkit/craftbukkit/entity/CraftPlayer.java
+@@ -3220,6 +3220,41 @@ public class CraftPlayer extends CraftHumanEntity implements Player {
+ public void showElderGuardian(boolean silent) {
+ if (getHandle().connection != null) getHandle().connection.send(new ClientboundGameEventPacket(ClientboundGameEventPacket.GUARDIAN_ELDER_EFFECT, silent ? 0F : 1F));
+ }
++
++ @Override
++ public int getWardenWarningCooldown() {
++ return this.getHandle().wardenSpawnTracker.cooldownTicks;
++ }
++
++ @Override
++ public void setWardenWarningCooldown(int cooldown) {
++ this.getHandle().wardenSpawnTracker.cooldownTicks = Math.max(cooldown, 0);
++ }
++
++ @Override
++ public int getWardenTimeSinceLastWarning() {
++ return this.getHandle().wardenSpawnTracker.ticksSinceLastWarning;
++ }
++
++ @Override
++ public void setWardenTimeSinceLastWarning(int time) {
++ this.getHandle().wardenSpawnTracker.ticksSinceLastWarning = time;
++ }
++
++ @Override
++ public int getWardenWarningLevel() {
++ return this.getHandle().wardenSpawnTracker.getWarningLevel();
++ }
++
++ @Override
++ public void setWardenWarningLevel(int warningLevel) {
++ this.getHandle().wardenSpawnTracker.setWarningLevel(warningLevel);
++ }
++
++ @Override
++ public void increaseWardenWarningLevel() {
++ this.getHandle().wardenSpawnTracker.increaseWarningLevel();
++ }
+ // Paper end
+
+ public Player.Spigot spigot()