summaryrefslogtreecommitdiffstats
path: root/src/main
diff options
context:
space:
mode:
authorTravis Watkins <amaranth@ubuntu.com>2013-12-09 13:43:02 -0600
committerTravis Watkins <amaranth@ubuntu.com>2013-12-09 13:43:02 -0600
commit772867eb51fc4137acceb7b9fb61b8bd742f9b8b (patch)
tree4a86ebef4030f9dfdb2ccf72ae6ea8378df2c22e /src/main
parent305e5f4f08a39976857ad9af61bfcf77fc9bfa78 (diff)
downloadcraftbukkit-772867eb51fc4137acceb7b9fb61b8bd742f9b8b.tar
craftbukkit-772867eb51fc4137acceb7b9fb61b8bd742f9b8b.tar.gz
craftbukkit-772867eb51fc4137acceb7b9fb61b8bd742f9b8b.tar.lz
craftbukkit-772867eb51fc4137acceb7b9fb61b8bd742f9b8b.tar.xz
craftbukkit-772867eb51fc4137acceb7b9fb61b8bd742f9b8b.zip
Call event when pistons push an item frame/painting. Fixes BUKKIT-5110
When pistons push/pull blocks they call Entity.move(float, float) to move entities out of their path. For hanging entities this code path makes them simply die and drop as an item. We now call an event in this scenario so plugins can control this behavior.
Diffstat (limited to 'src/main')
-rw-r--r--src/main/java/net/minecraft/server/EntityHanging.java14
1 files changed, 12 insertions, 2 deletions
diff --git a/src/main/java/net/minecraft/server/EntityHanging.java b/src/main/java/net/minecraft/server/EntityHanging.java
index 4de0b17b..670ca65b 100644
--- a/src/main/java/net/minecraft/server/EntityHanging.java
+++ b/src/main/java/net/minecraft/server/EntityHanging.java
@@ -237,7 +237,7 @@ public abstract class EntityHanging extends Entity {
this.world.getServer().getPluginManager().callEvent(paintingEvent);
}
- if (dead || event.isCancelled() || (paintingEvent != null && paintingEvent.isCancelled())) {
+ if (this.dead || event.isCancelled() || (paintingEvent != null && paintingEvent.isCancelled())) {
return true;
}
// CraftBukkit end
@@ -253,7 +253,17 @@ public abstract class EntityHanging extends Entity {
public void move(double d0, double d1, double d2) {
if (!this.world.isStatic && !this.dead && d0 * d0 + d1 * d1 + d2 * d2 > 0.0D) {
- if (dead) return; // CraftBukkit
+ if (this.dead) return; // CraftBukkit
+
+ // CraftBukkit start
+ // TODO - Does this need its own cause? Seems to only be triggered by pistons
+ HangingBreakEvent event = new HangingBreakEvent((Hanging) this.getBukkitEntity(), HangingBreakEvent.RemoveCause.PHYSICS);
+ this.world.getServer().getPluginManager().callEvent(event);
+
+ if (this.dead || event.isCancelled()) {
+ return;
+ }
+ // CraftBukkit end
this.die();
this.b((Entity) null);