From a9f92a7086761c138108a5ff87beed319095c6af Mon Sep 17 00:00:00 2001 From: CraftBukkit/Spigot Date: Tue, 28 Jul 2020 19:05:03 +1000 Subject: [PATCH] SPIGOT-6032: Add best effort target events for new entities By: md_5 --- .../BehaviorAttackTargetForget.patch | 32 ++++++++++++++++ .../nms-patches/BehaviorAttackTargetSet.patch | 38 +++++++++++++++++++ 2 files changed, 70 insertions(+) create mode 100644 paper-server/nms-patches/BehaviorAttackTargetForget.patch create mode 100644 paper-server/nms-patches/BehaviorAttackTargetSet.patch diff --git a/paper-server/nms-patches/BehaviorAttackTargetForget.patch b/paper-server/nms-patches/BehaviorAttackTargetForget.patch new file mode 100644 index 0000000000..45eff8c895 --- /dev/null +++ b/paper-server/nms-patches/BehaviorAttackTargetForget.patch @@ -0,0 +1,32 @@ +--- a/net/minecraft/server/BehaviorAttackTargetForget.java ++++ b/net/minecraft/server/BehaviorAttackTargetForget.java +@@ -3,6 +3,11 @@ + import com.google.common.collect.ImmutableMap; + import java.util.Optional; + import java.util.function.Predicate; ++// CraftBukkit start ++import org.bukkit.craftbukkit.entity.CraftLivingEntity; ++import org.bukkit.craftbukkit.event.CraftEventFactory; ++import org.bukkit.event.entity.EntityTargetEvent; ++// CraftBukkit end + + public class BehaviorAttackTargetForget extends Behavior { + +@@ -54,6 +59,17 @@ + } + + private void d(E e0) { ++ // CraftBukkit start ++ EntityLiving old = e0.getBehaviorController().getMemory(MemoryModuleType.ATTACK_TARGET).orElse(null); ++ EntityTargetEvent event = CraftEventFactory.callEntityTargetLivingEvent(e0, old, (old != null && !old.isAlive()) ? EntityTargetEvent.TargetReason.TARGET_DIED : EntityTargetEvent.TargetReason.FORGOT_TARGET); ++ if (event.isCancelled()) { ++ return; ++ } ++ if (event.getTarget() != null) { ++ e0.getBehaviorController().setMemory(MemoryModuleType.ATTACK_TARGET, ((CraftLivingEntity) event.getTarget()).getHandle()); ++ return; ++ } ++ // CraftBukkit end + e0.getBehaviorController().removeMemory(MemoryModuleType.ATTACK_TARGET); + } + } diff --git a/paper-server/nms-patches/BehaviorAttackTargetSet.patch b/paper-server/nms-patches/BehaviorAttackTargetSet.patch new file mode 100644 index 0000000000..c2476ef323 --- /dev/null +++ b/paper-server/nms-patches/BehaviorAttackTargetSet.patch @@ -0,0 +1,38 @@ +--- a/net/minecraft/server/BehaviorAttackTargetSet.java ++++ b/net/minecraft/server/BehaviorAttackTargetSet.java +@@ -4,6 +4,11 @@ + import java.util.Optional; + import java.util.function.Function; + import java.util.function.Predicate; ++// CraftBukkit start ++import org.bukkit.craftbukkit.entity.CraftLivingEntity; ++import org.bukkit.craftbukkit.event.CraftEventFactory; ++import org.bukkit.event.entity.EntityTargetEvent; ++// CraftBukkit end + + public class BehaviorAttackTargetSet extends Behavior { + +@@ -33,13 +38,21 @@ + } + + protected void a(WorldServer worldserver, E e0, long i) { +- ((Optional) this.c.apply(e0)).ifPresent((entityliving) -> { ++ (this.c.apply(e0)).ifPresent((entityliving) -> { // CraftBukkit - decompile error + this.a(e0, entityliving); + }); + } + + private void a(E e0, EntityLiving entityliving) { +- e0.getBehaviorController().setMemory(MemoryModuleType.ATTACK_TARGET, (Object) entityliving); ++ // CraftBukkit start ++ EntityTargetEvent event = CraftEventFactory.callEntityTargetLivingEvent(e0, entityliving, (entityliving instanceof EntityPlayer) ? EntityTargetEvent.TargetReason.CLOSEST_PLAYER : EntityTargetEvent.TargetReason.CLOSEST_ENTITY); ++ if (event.isCancelled()) { ++ return; ++ } ++ entityliving = (event.getTarget() != null) ? ((CraftLivingEntity) event.getTarget()).getHandle() : null; ++ // CraftBukkit end ++ ++ e0.getBehaviorController().setMemory(MemoryModuleType.ATTACK_TARGET, entityliving); // CraftBukkit - decompile error + e0.getBehaviorController().removeMemory(MemoryModuleType.CANT_REACH_WALK_TARGET_SINCE); + } + }