From 03d5d38a6ae9a54b761fcd544f3d928ed5f5ab66 Mon Sep 17 00:00:00 2001 From: Tamion <70228790+notTamion@users.noreply.github.com> Date: Fri, 9 Feb 2024 21:56:13 +0100 Subject: [PATCH] Add Arrow/Stinger Removal Time API (#10193) --- ...working-with-arrows-stuck-in-living-.patch | 18 +++++++++++++++ patches/api/Stinger-API.patch | 20 +++++++++++++++-- ...working-with-arrows-stuck-in-living-.patch | 14 ++++++++++++ patches/server/Stinger-API.patch | 22 +++++++++++++++++-- 4 files changed, 70 insertions(+), 4 deletions(-) diff --git a/patches/api/Add-methods-for-working-with-arrows-stuck-in-living-.patch b/patches/api/Add-methods-for-working-with-arrows-stuck-in-living-.patch index 5e04a3cb1b..51848e555b 100644 --- a/patches/api/Add-methods-for-working-with-arrows-stuck-in-living-.patch +++ b/patches/api/Add-methods-for-working-with-arrows-stuck-in-living-.patch @@ -35,6 +35,24 @@ index 0000000000000000000000000000000000000000..00000000000000000000000000000000 */ - public void setArrowsInBody(int count); + void setArrowsInBody(int count, boolean fireEvent); // Paper ++ ++ // Paper start - Add methods for working with arrows stuck in living entities ++ /** ++ * Sets the amount of ticks before the next arrow gets removed from the entities body. ++ * <p> ++ * A value of 0 will cause the server to re-calculate the amount of ticks on the next tick. ++ * ++ * @param ticks Amount of ticks ++ */ ++ void setNextArrowRemoval(@org.jetbrains.annotations.Range(from = 0, to = Integer.MAX_VALUE) int ticks); ++ ++ /** ++ * Gets the amount of ticks before the next arrow gets removed from the entities body. ++ * ++ * @return ticks Amount of ticks ++ */ ++ int getNextArrowRemoval(); ++ // Paper end - Add methods for working with arrows stuck in living entities /** * Returns the living entity's current maximum no damage ticks. diff --git a/patches/api/Stinger-API.patch b/patches/api/Stinger-API.patch index 55649a4b21..1c8445fb54 100644 --- a/patches/api/Stinger-API.patch +++ b/patches/api/Stinger-API.patch @@ -9,8 +9,8 @@ index 0000000000000000000000000000000000000000..00000000000000000000000000000000 --- a/src/main/java/org/bukkit/entity/LivingEntity.java +++ b/src/main/java/org/bukkit/entity/LivingEntity.java @@ -0,0 +0,0 @@ public interface LivingEntity extends Attributable, Damageable, ProjectileSource - */ - void setArrowsInBody(int count, boolean fireEvent); // Paper + int getNextArrowRemoval(); + // Paper end - Add methods for working with arrows stuck in living entities + // Paper start - Bee Stinger API + /** @@ -40,6 +40,22 @@ index 0000000000000000000000000000000000000000..00000000000000000000000000000000 + * @param count amount of bee stingers in entity's body + */ + public void setBeeStingersInBody(int count); ++ ++ /** ++ * Sets the amount of ticks before the next bee stinger gets removed from the entities body. ++ * <p> ++ * A value of 0 will cause the server to re-calculate the amount of ticks on the next tick. ++ * ++ * @param ticks Amount of ticks ++ */ ++ void setNextBeeStingerRemoval(@org.jetbrains.annotations.Range(from = 0, to = Integer.MAX_VALUE) int ticks); ++ ++ /** ++ * Gets the amount of ticks before the next bee stinger gets removed from the entities body. ++ * ++ * @return ticks Amount of ticks ++ */ ++ int getNextBeeStingerRemoval(); + // Paper end - Stinger API + /** diff --git a/patches/server/Add-methods-for-working-with-arrows-stuck-in-living-.patch b/patches/server/Add-methods-for-working-with-arrows-stuck-in-living-.patch index ec65d40e92..4752343498 100644 --- a/patches/server/Add-methods-for-working-with-arrows-stuck-in-living-.patch +++ b/patches/server/Add-methods-for-working-with-arrows-stuck-in-living-.patch @@ -24,9 +24,23 @@ index 0000000000000000000000000000000000000000..00000000000000000000000000000000 + this.getHandle().setArrowCount(count); + } + // Paper end ++ } ++ ++ // Paper start - Add methods for working with arrows stuck in living entities ++ @Override ++ public void setNextArrowRemoval(final int ticks) { ++ Preconditions.checkArgument(ticks >= 0, "New amount of ticks before next arrow removal must be >= 0"); ++ this.getHandle().removeArrowTime = ticks; ++ } ++ ++ @Override ++ public int getNextArrowRemoval() { ++ return this.getHandle().removeArrowTime; } ++ // Paper end - Add methods for working with arrows stuck in living entities @Override + public void damage(double amount) { @@ -0,0 +0,0 @@ public class CraftLivingEntity extends CraftEntity implements LivingEntity { this.getHandle().persistentInvisibility = invisible; this.getHandle().setSharedFlag(5, invisible); diff --git a/patches/server/Stinger-API.patch b/patches/server/Stinger-API.patch index b5b1fb3430..14583dd001 100644 --- a/patches/server/Stinger-API.patch +++ b/patches/server/Stinger-API.patch @@ -17,12 +17,18 @@ index 0000000000000000000000000000000000000000..00000000000000000000000000000000 + public int getBeeStingerCooldown() { + return getHandle().removeStingerTime; + } -+ + + // Paper start - Add methods for working with arrows stuck in living entities + @Override +@@ -0,0 +0,0 @@ public class CraftLivingEntity extends CraftEntity implements LivingEntity { + } + // Paper end - Add methods for working with arrows stuck in living entities + + @Override + public void setBeeStingerCooldown(int ticks) { + getHandle().removeStingerTime = ticks; + } - ++ + @Override + public int getBeeStingersInBody() { + return getHandle().getStingerCount(); @@ -33,7 +39,19 @@ index 0000000000000000000000000000000000000000..00000000000000000000000000000000 + Preconditions.checkArgument(count >= 0, "New bee stinger amount must be >= 0"); + getHandle().setStingerCount(count); + } ++ ++ @Override ++ public void setNextBeeStingerRemoval(final int ticks) { ++ Preconditions.checkArgument(ticks >= 0, "New amount of ticks before next bee stinger removal must be >= 0"); ++ this.getHandle().removeStingerTime = ticks; ++ } ++ ++ @Override ++ public int getNextBeeStingerRemoval() { ++ return this.getHandle().removeStingerTime; ++ } + // Paper end - Bee Stinger API ++ @Override public void damage(double amount) { this.damage(amount, null);