2020-07-28 11:05:03 +02:00
|
|
|
--- a/net/minecraft/server/BehaviorAttackTargetForget.java
|
|
|
|
+++ b/net/minecraft/server/BehaviorAttackTargetForget.java
|
2021-03-08 22:47:33 +01:00
|
|
|
@@ -4,6 +4,12 @@
|
2020-07-28 11:05:03 +02:00
|
|
|
import java.util.Optional;
|
|
|
|
import java.util.function.Predicate;
|
2021-03-08 22:47:33 +01:00
|
|
|
|
2020-07-28 11:05:03 +02:00
|
|
|
+// CraftBukkit start
|
|
|
|
+import org.bukkit.craftbukkit.entity.CraftLivingEntity;
|
|
|
|
+import org.bukkit.craftbukkit.event.CraftEventFactory;
|
|
|
|
+import org.bukkit.event.entity.EntityTargetEvent;
|
|
|
|
+// CraftBukkit end
|
2021-03-08 22:47:33 +01:00
|
|
|
+
|
2020-07-28 11:05:03 +02:00
|
|
|
public class BehaviorAttackTargetForget<E extends EntityInsentient> extends Behavior<E> {
|
|
|
|
|
2021-03-08 22:47:33 +01:00
|
|
|
private final Predicate<EntityLiving> b;
|
|
|
|
@@ -54,6 +60,17 @@
|
2020-07-28 11:05:03 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
private void d(E e0) {
|
|
|
|
+ // CraftBukkit start
|
|
|
|
+ EntityLiving old = e0.getBehaviorController().getMemory(MemoryModuleType.ATTACK_TARGET).orElse(null);
|
2020-08-23 11:14:58 +02:00
|
|
|
+ EntityTargetEvent event = CraftEventFactory.callEntityTargetLivingEvent(e0, null, (old != null && !old.isAlive()) ? EntityTargetEvent.TargetReason.TARGET_DIED : EntityTargetEvent.TargetReason.FORGOT_TARGET);
|
2020-07-28 11:05:03 +02:00
|
|
|
+ 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);
|
|
|
|
}
|
|
|
|
}
|