From 1eb289b1a3bd1fbf8b7d6f3d4515c03804e8bcaf Mon Sep 17 00:00:00 2001 From: Bukkit/Spigot Date: Tue, 7 Nov 2017 19:32:15 +1100 Subject: [PATCH] SPIGOT-3629: Greatly expand entity effect API By: md_5 --- .../main/java/org/bukkit/EntityEffect.java | 153 ++++++++++++------ .../main/java/org/bukkit/entity/Entity.java | 2 + .../main/java/org/bukkit/entity/Tameable.java | 2 +- 3 files changed, 108 insertions(+), 49 deletions(-) diff --git a/paper-api/src/main/java/org/bukkit/EntityEffect.java b/paper-api/src/main/java/org/bukkit/EntityEffect.java index c816edfdf3..561da3da5a 100644 --- a/paper-api/src/main/java/org/bukkit/EntityEffect.java +++ b/paper-api/src/main/java/org/bukkit/EntityEffect.java @@ -3,104 +3,153 @@ package org.bukkit; import java.util.Map; import com.google.common.collect.Maps; +import org.bukkit.entity.Ageable; +import org.bukkit.entity.ArmorStand; +import org.bukkit.entity.Entity; +import org.bukkit.entity.Firework; +import org.bukkit.entity.Guardian; +import org.bukkit.entity.IronGolem; +import org.bukkit.entity.LivingEntity; +import org.bukkit.entity.Rabbit; +import org.bukkit.entity.Squid; +import org.bukkit.entity.Tameable; +import org.bukkit.entity.TippedArrow; +import org.bukkit.entity.Villager; +import org.bukkit.entity.Witch; +import org.bukkit.entity.Wolf; +import org.bukkit.entity.ZombieVillager; /** * A list of all Effects that can happen to entities. */ public enum EntityEffect { + /** + * Colored particles from a tipped arrow. + */ + ARROW_PARTICLES(0, TippedArrow.class), + /** + * Rabbit jumping. + */ + RABBIT_JUMP(1, Rabbit.class), /** * When mobs get hurt. */ - HURT(2), - + HURT(2, LivingEntity.class), /** * When a mob dies. *

* This will cause client-glitches! */ - DEATH(3), - + DEATH(3, LivingEntity.class), + /** + * Iron golem attacking. + */ + GOLEM_ATTACK(4, IronGolem.class), + // 5 - unused /** * The smoke when taming a wolf fails. - *

- * Without client-mods this will be ignored if the entity is not a wolf. */ - WOLF_SMOKE(6), - + WOLF_SMOKE(6, Tameable.class), /** * The hearts when taming a wolf succeeds. - *

- * Without client-mods this will be ignored if the entity is not a wolf. */ - WOLF_HEARTS(7), - + WOLF_HEARTS(7, Wolf.class), /** * When a wolf shakes (after being wet). - *

- * Without client-mods this will be ignored if the entity is not a wolf. */ - WOLF_SHAKE(8), - + WOLF_SHAKE(8, Wolf.class), + // 9 - unused /** - * When a sheep eats a LONG_GRASS block. + * When an entity eats a LONG_GRASS block. */ - SHEEP_EAT(10), - + SHEEP_EAT(10, LivingEntity.class), /** * When an Iron Golem gives a rose. - *

- * This will not play an effect if the entity is not an iron golem. */ - IRON_GOLEM_ROSE(11), - + IRON_GOLEM_ROSE(11, IronGolem.class), /** * Hearts from a villager. - *

- * This will not play an effect if the entity is not a villager. */ - VILLAGER_HEART(12), - + VILLAGER_HEART(12, Villager.class), /** * When a villager is angry. - *

- * This will not play an effect if the entity is not a villager. */ - VILLAGER_ANGRY(13), - + VILLAGER_ANGRY(13, Villager.class), /** * Happy particles from a villager. - *

- * This will not play an effect if the entity is not a villager. */ - VILLAGER_HAPPY(14), - + VILLAGER_HAPPY(14, Villager.class), /** * Magic particles from a witch. - *

- * This will not play an effect if the entity is not a witch. */ - WITCH_MAGIC(15), - + WITCH_MAGIC(15, Witch.class), /** * When a zombie transforms into a villager by shaking violently. - *

- * This will not play an effect if the entity is not a zombie. */ - ZOMBIE_TRANSFORM(16), - + ZOMBIE_TRANSFORM(16, ZombieVillager.class), /** * When a firework explodes. - *

- * This will not play an effect if the entity is not a firework. */ - FIREWORK_EXPLODE(17); + FIREWORK_EXPLODE(17, Firework.class), + /** + * Hearts from a breeding entity. + */ + LOVE_HEARTS(18, Ageable.class), + /** + * Resets squid rotation. + */ + SQUID_ROTATE(19, Squid.class), + /** + * Silverfish entering block, spawner spawning. + */ + ENTITY_POOF(20, LivingEntity.class), + /** + * Guardian sets laser target. + */ + GUARDIAN_TARGET(21, Guardian.class), + // 22-28 player internal flags + /** + * Shield blocks attack. + */ + SHIELD_BLOCK(29, LivingEntity.class), + /** + * Shield breaks. + */ + SHIELD_BREAK(30, LivingEntity.class), + // 31 - unused + /** + * Armor stand is hit. + */ + ARMOR_STAND_HIT(32, ArmorStand.class), + /** + * Entity hurt by thorns attack. + */ + THORNS_HURT(33, LivingEntity.class), + /** + * Iron golem puts away rose. + */ + IRON_GOLEM_SHEATH(34, IronGolem.class), + /** + * Totem prevents entity death. + */ + TOTEM_RESURRECT(35, LivingEntity.class), + /** + * Entity hurt due to drowning damage. + */ + HURT_DROWN(36, LivingEntity.class), + /** + * Entity hurt due to explosion damage. + */ + HURT_EXPLOSION(37, LivingEntity.class); private final byte data; + private final Class applicable; private final static Map BY_DATA = Maps.newHashMap(); - EntityEffect(final int data) { + EntityEffect(final int data, Class clazz) { this.data = (byte) data; + this.applicable = clazz; } /** @@ -114,6 +163,15 @@ public enum EntityEffect { return data; } + /** + * Gets entity superclass which this affect is applicable to. + * + * @return applicable class + */ + public Class getApplicable() { + return applicable; + } + /** * Gets the EntityEffect with the given data value * @@ -127,7 +185,6 @@ public enum EntityEffect { return BY_DATA.get(data); } - static { for (EntityEffect entityEffect : values()) { BY_DATA.put(entityEffect.data, entityEffect); diff --git a/paper-api/src/main/java/org/bukkit/entity/Entity.java b/paper-api/src/main/java/org/bukkit/entity/Entity.java index 84ae807c04..ab64a0c615 100644 --- a/paper-api/src/main/java/org/bukkit/entity/Entity.java +++ b/paper-api/src/main/java/org/bukkit/entity/Entity.java @@ -311,6 +311,8 @@ public interface Entity extends Metadatable, CommandSender, Nameable { * Performs the specified {@link EntityEffect} for this entity. *

* This will be viewable to all players near the entity. + *

+ * If the effect is not applicable to this class of entity, it will not play. * * @param type Effect to play. */ diff --git a/paper-api/src/main/java/org/bukkit/entity/Tameable.java b/paper-api/src/main/java/org/bukkit/entity/Tameable.java index 014885dac1..44497aa3c4 100644 --- a/paper-api/src/main/java/org/bukkit/entity/Tameable.java +++ b/paper-api/src/main/java/org/bukkit/entity/Tameable.java @@ -1,6 +1,6 @@ package org.bukkit.entity; -public interface Tameable { +public interface Tameable extends Entity { /** * Check if this is tamed