From 0920b90195c5eb84261281bfb3e7a9fcde527efd Mon Sep 17 00:00:00 2001 From: MrBretzel Date: Thu, 14 Dec 2023 18:50:05 +0100 Subject: [PATCH] Add more method to Entity for PotionEffect (#85) (cherry picked from commit 8edc9981d041c802abede92e8f1aec1ef8db225a) --- .../net/minestom/server/entity/Entity.java | 30 +++++++++++++++++++ 1 file changed, 30 insertions(+) diff --git a/src/main/java/net/minestom/server/entity/Entity.java b/src/main/java/net/minestom/server/entity/Entity.java index a5d3ef46e..19591c428 100644 --- a/src/main/java/net/minestom/server/entity/Entity.java +++ b/src/main/java/net/minestom/server/entity/Entity.java @@ -1477,6 +1477,36 @@ public class Entity implements Viewable, Tickable, Schedulable, Snapshotable, Ev }); } + /** + * If the entity has the specified effect. + * + * @param effect the effect to check + */ + public boolean hasEffect(@NotNull PotionEffect effect) { + return this.effects.stream().anyMatch(timedPotion -> timedPotion.getPotion().effect() == effect); + } + + /** + * Gets the TimedPotion of the specified effect. + * + * @param effect the effect type + * @return the effect, null if not found + */ + public @Nullable TimedPotion getEffect(@NotNull PotionEffect effect) { + return this.effects.stream().filter(timedPotion -> timedPotion.getPotion().effect() == effect).findFirst().orElse(null); + } + + /** + * Gets the level of the specified effect. + * + * @param effect the effect type + * @return the effect level, 0 if not found + */ + public int getEffectLevel(@NotNull PotionEffect effect) { + TimedPotion timedPotion = getEffect(effect); + return timedPotion == null ? 0 : timedPotion.getPotion().amplifier(); + } + /** * Removes all the effects currently applied to the entity. */