From ae4cd083ac050465aec68cfa0458deb839270fac Mon Sep 17 00:00:00 2001 From: Bukkit/Spigot Date: Tue, 29 Nov 2011 20:50:38 +1100 Subject: [PATCH] Extend EntityCombustEvent to allow setting combustion duration. Also extend with two new events that track the entity or block that caused the combustion. By: Andrew Ardill --- .../java/org/bukkit/entity/Projectile.java | 2 ++ .../entity/EntityCombustByBlockEvent.java | 24 ++++++++++++++++++ .../entity/EntityCombustByEntityEvent.java | 21 ++++++++++++++++ .../event/entity/EntityCombustEvent.java | 25 ++++++++++++++++--- .../bukkit/event/entity/EntityListener.java | 2 +- 5 files changed, 70 insertions(+), 4 deletions(-) create mode 100644 paper-api/src/main/java/org/bukkit/event/entity/EntityCombustByBlockEvent.java create mode 100644 paper-api/src/main/java/org/bukkit/event/entity/EntityCombustByEntityEvent.java diff --git a/paper-api/src/main/java/org/bukkit/entity/Projectile.java b/paper-api/src/main/java/org/bukkit/entity/Projectile.java index 95aae5f9f1..c8212540b7 100644 --- a/paper-api/src/main/java/org/bukkit/entity/Projectile.java +++ b/paper-api/src/main/java/org/bukkit/entity/Projectile.java @@ -25,6 +25,8 @@ public interface Projectile extends Entity { /** * Determine if this projectile should bounce or not when it hits. * + * If a small fireball does not bounce it will set the target on fire. + * * @return true if it should bounce. */ public boolean doesBounce(); diff --git a/paper-api/src/main/java/org/bukkit/event/entity/EntityCombustByBlockEvent.java b/paper-api/src/main/java/org/bukkit/event/entity/EntityCombustByBlockEvent.java new file mode 100644 index 0000000000..addb42fd75 --- /dev/null +++ b/paper-api/src/main/java/org/bukkit/event/entity/EntityCombustByBlockEvent.java @@ -0,0 +1,24 @@ +package org.bukkit.event.entity; + +import org.bukkit.block.Block; +import org.bukkit.entity.Entity; + +public class EntityCombustByBlockEvent extends EntityCombustEvent { + + private Block combuster; + + public EntityCombustByBlockEvent(Block combuster, Entity combustee, int duration) { + super(combustee, duration); + this.combuster = combuster; + } + + /** + * The combuster can be lava or a block that is on fire. + * + * WARNING: block may be null. + * @return the Block that set the combustee alight. + */ + public Block getCombuster() { + return combuster; + } +} diff --git a/paper-api/src/main/java/org/bukkit/event/entity/EntityCombustByEntityEvent.java b/paper-api/src/main/java/org/bukkit/event/entity/EntityCombustByEntityEvent.java new file mode 100644 index 0000000000..15ab75f195 --- /dev/null +++ b/paper-api/src/main/java/org/bukkit/event/entity/EntityCombustByEntityEvent.java @@ -0,0 +1,21 @@ +package org.bukkit.event.entity; + +import org.bukkit.entity.Entity; + +public class EntityCombustByEntityEvent extends EntityCombustEvent { + + private Entity combuster; + + public EntityCombustByEntityEvent(Entity combuster, Entity combustee, int duration) { + super(combustee, duration); + this.combuster = combuster; + } + + /** + * The combuster can be a WeatherStorm a Blaze, or an Entity holding a FIRE_ASPECT enchanted item. + * @return the Entity that set the combustee alight. + */ + public Entity getCombuster() { + return combuster; + } +} diff --git a/paper-api/src/main/java/org/bukkit/event/entity/EntityCombustEvent.java b/paper-api/src/main/java/org/bukkit/event/entity/EntityCombustEvent.java index 0587576ed4..9b3f38f3ee 100644 --- a/paper-api/src/main/java/org/bukkit/event/entity/EntityCombustEvent.java +++ b/paper-api/src/main/java/org/bukkit/event/entity/EntityCombustEvent.java @@ -4,15 +4,17 @@ import org.bukkit.entity.Entity; import org.bukkit.event.Cancellable; /** - * Called when an entity combusts due to the sun. + * Called when an entity combusts. *

* If an Entity Combust event is cancelled, the entity will not combust. */ public class EntityCombustEvent extends EntityEvent implements Cancellable { + private int duration; private boolean cancel; - public EntityCombustEvent(Entity what) { - super(Type.ENTITY_COMBUST, what); + public EntityCombustEvent(Entity combustee, int duration) { + super(Type.ENTITY_COMBUST, combustee); + this.duration = duration; this.cancel = false; } @@ -23,4 +25,21 @@ public class EntityCombustEvent extends EntityEvent implements Cancellable { public void setCancelled(boolean cancel) { this.cancel = cancel; } + + /** + * @return the amount of time (in seconds) the combustee should be alight for + */ + public int getDuration() { + return duration; + } + + /** + * The number of seconds the combustee should be alight for. + * + * This value will only ever increase the combustion time, not decrease existing combustion times. + * @param duration the time in seconds to be alight for. + */ + public void setDuration(int duration) { + this.duration = duration; + } } diff --git a/paper-api/src/main/java/org/bukkit/event/entity/EntityListener.java b/paper-api/src/main/java/org/bukkit/event/entity/EntityListener.java index c325cb3780..3e8db64e82 100644 --- a/paper-api/src/main/java/org/bukkit/event/entity/EntityListener.java +++ b/paper-api/src/main/java/org/bukkit/event/entity/EntityListener.java @@ -27,7 +27,7 @@ public class EntityListener implements Listener { public void onItemSpawn(ItemSpawnEvent event) {} /** - * Called when an entity combusts due to the sun. + * Called when an entity combusts. *

* If an Entity Combust event is cancelled, the entity will not combust. *