diff --git a/Spigot-API-Patches/Add-hit-entity-to-ProjectileHitEvent.patch b/Spigot-API-Patches/Add-hit-entity-to-ProjectileHitEvent.patch new file mode 100644 index 000000000..ddcd7745f --- /dev/null +++ b/Spigot-API-Patches/Add-hit-entity-to-ProjectileHitEvent.patch @@ -0,0 +1,62 @@ +From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001 +From: AlphaBlend +Date: Wed, 21 Sep 2016 20:40:21 -0700 +Subject: [PATCH] Add hit entity to ProjectileHitEvent + + +diff --git a/src/main/java/org/bukkit/event/entity/ProjectileHitEvent.java b/src/main/java/org/bukkit/event/entity/ProjectileHitEvent.java +index 0000000000000000000000000000000000000000..0000000000000000000000000000000000000000 100644 +--- a/src/main/java/org/bukkit/event/entity/ProjectileHitEvent.java ++++ b/src/main/java/org/bukkit/event/entity/ProjectileHitEvent.java +@@ -0,0 +0,0 @@ + package org.bukkit.event.entity; + ++import org.bukkit.entity.Entity; // Paper + import org.bukkit.entity.Projectile; + import org.bukkit.event.HandlerList; + ++import javax.annotation.Nullable; ++ + /** + * Called when a projectile hits an object + */ + public class ProjectileHitEvent extends EntityEvent { + private static final HandlerList handlers = new HandlerList(); ++ // Paper start ++ @Nullable ++ private final Entity hitEntity; + + public ProjectileHitEvent(final Projectile projectile) { ++ this(projectile, null); ++ } ++ ++ public ProjectileHitEvent(final Projectile projectile, @Nullable final Entity hitEntity) { + super(projectile); ++ this.hitEntity = hitEntity; + } ++ // Paper end + + @Override + public Projectile getEntity() { + return (Projectile) entity; + } + ++ // Paper start ++ /** ++ * Gets the entity that was hit by the projectile. ++ * ++ * This may be null, depending on if the projectile ++ * actually hit an entity. ++ * ++ * @return The entity that was hit, or null otherwise ++ */ ++ @Nullable ++ public Entity getHitEntity() { ++ return hitEntity; ++ } ++ // Paper end ++ + @Override + public HandlerList getHandlers() { + return handlers; +-- \ No newline at end of file diff --git a/Spigot-Server-Patches/Add-hit-entity-to-ProjectileHitEvent.patch b/Spigot-Server-Patches/Add-hit-entity-to-ProjectileHitEvent.patch new file mode 100644 index 000000000..fd267813b --- /dev/null +++ b/Spigot-Server-Patches/Add-hit-entity-to-ProjectileHitEvent.patch @@ -0,0 +1,79 @@ +From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001 +From: AlphaBlend +Date: Wed, 21 Sep 2016 20:40:46 -0700 +Subject: [PATCH] Add hit entity to ProjectileHitEvent + + +diff --git a/src/main/java/net/minecraft/server/EntityArrow.java b/src/main/java/net/minecraft/server/EntityArrow.java +index 0000000000000000000000000000000000000000..0000000000000000000000000000000000000000 100644 +--- a/src/main/java/net/minecraft/server/EntityArrow.java ++++ b/src/main/java/net/minecraft/server/EntityArrow.java +@@ -0,0 +0,0 @@ public abstract class EntityArrow extends Entity implements IProjectile { + + protected void a(MovingObjectPosition movingobjectposition) { + Entity entity = movingobjectposition.entity; +- org.bukkit.craftbukkit.event.CraftEventFactory.callProjectileHitEvent(this); // CraftBukkit - Call event ++ org.bukkit.craftbukkit.event.CraftEventFactory.callProjectileHitEvent(this, entity); // CraftBukkit - Call event // Paper - Include entity in movingobjectposition + if (entity != null) { + float f = MathHelper.sqrt(this.motX * this.motX + this.motY * this.motY + this.motZ * this.motZ); + int i = MathHelper.f((double) f * this.damage); +diff --git a/src/main/java/net/minecraft/server/EntityFireball.java b/src/main/java/net/minecraft/server/EntityFireball.java +index 0000000000000000000000000000000000000000..0000000000000000000000000000000000000000 100644 +--- a/src/main/java/net/minecraft/server/EntityFireball.java ++++ b/src/main/java/net/minecraft/server/EntityFireball.java +@@ -0,0 +0,0 @@ public abstract class EntityFireball extends Entity { + + // CraftBukkit start - Fire ProjectileHitEvent + if (this.dead) { +- CraftEventFactory.callProjectileHitEvent(this); ++ CraftEventFactory.callProjectileHitEvent(this, movingobjectposition.entity); // Paper - include entity in movingobjectposition + } + // CraftBukkit end + } +diff --git a/src/main/java/net/minecraft/server/EntityFishingHook.java b/src/main/java/net/minecraft/server/EntityFishingHook.java +index 0000000000000000000000000000000000000000..0000000000000000000000000000000000000000 100644 +--- a/src/main/java/net/minecraft/server/EntityFishingHook.java ++++ b/src/main/java/net/minecraft/server/EntityFishingHook.java +@@ -0,0 +0,0 @@ public class EntityFishingHook extends Entity { + // Paper end + + if (movingobjectposition != null) { +- org.bukkit.craftbukkit.event.CraftEventFactory.callProjectileHitEvent(this); // Craftbukkit - Call event ++ org.bukkit.craftbukkit.event.CraftEventFactory.callProjectileHitEvent(this, movingobjectposition.entity); // Craftbukkit - Call event // Paper - Include entity in movingobjectposition + if (movingobjectposition.entity != null) { + this.hooked = movingobjectposition.entity; + this.getDataWatcher().set(EntityFishingHook.c, Integer.valueOf(this.hooked.getId() + 1)); +diff --git a/src/main/java/net/minecraft/server/EntityProjectile.java b/src/main/java/net/minecraft/server/EntityProjectile.java +index 0000000000000000000000000000000000000000..0000000000000000000000000000000000000000 100644 +--- a/src/main/java/net/minecraft/server/EntityProjectile.java ++++ b/src/main/java/net/minecraft/server/EntityProjectile.java +@@ -0,0 +0,0 @@ public abstract class EntityProjectile extends Entity implements IProjectile { + this.a(movingobjectposition); + // CraftBukkit start + if (this.dead) { +- org.bukkit.craftbukkit.event.CraftEventFactory.callProjectileHitEvent(this); ++ org.bukkit.craftbukkit.event.CraftEventFactory.callProjectileHitEvent(this, movingobjectposition.entity); // Paper - include Entity in movingobjectposition + } + // CraftBukkit end + } +diff --git a/src/main/java/org/bukkit/craftbukkit/event/CraftEventFactory.java b/src/main/java/org/bukkit/craftbukkit/event/CraftEventFactory.java +index 0000000000000000000000000000000000000000..0000000000000000000000000000000000000000 100644 +--- a/src/main/java/org/bukkit/craftbukkit/event/CraftEventFactory.java ++++ b/src/main/java/org/bukkit/craftbukkit/event/CraftEventFactory.java +@@ -0,0 +0,0 @@ public class CraftEventFactory { + return event; + } + ++ // Paper start ++ public static ProjectileHitEvent callProjectileHitEvent(Entity entity, Entity hitEntity) { ++ ProjectileHitEvent event = new ProjectileHitEvent((Projectile) entity.getBukkitEntity(), (hitEntity == null ? null : hitEntity.getBukkitEntity())); ++ ++ entity.world.getServer().getPluginManager().callEvent(event); ++ return event; ++ } ++ // Paper end ++ + public static ExpBottleEvent callExpBottleEvent(Entity entity, int exp) { + ThrownExpBottle bottle = (ThrownExpBottle) entity.getBukkitEntity(); + ExpBottleEvent event = new ExpBottleEvent(bottle, exp); +-- \ No newline at end of file