2022-11-10 04:05:58 +01:00
|
|
|
From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001
|
|
|
|
From: Owen1212055 <23108066+Owen1212055@users.noreply.github.com>
|
|
|
|
Date: Sun, 18 Sep 2022 13:10:18 -0400
|
|
|
|
Subject: [PATCH] Add PrePlayerAttackEntityEvent
|
|
|
|
|
|
|
|
|
|
|
|
diff --git a/src/main/java/net/minecraft/world/entity/player/Player.java b/src/main/java/net/minecraft/world/entity/player/Player.java
|
2022-12-07 17:46:46 +01:00
|
|
|
index 4b2495aed39450eb148627a0787848fd7c35f1f9..0ea101f155936f7c340d9e1d1077c58b72551027 100644
|
2022-11-10 04:05:58 +01:00
|
|
|
--- a/src/main/java/net/minecraft/world/entity/player/Player.java
|
|
|
|
+++ b/src/main/java/net/minecraft/world/entity/player/Player.java
|
|
|
|
@@ -1251,8 +1251,17 @@ public abstract class Player extends LivingEntity {
|
|
|
|
}
|
|
|
|
|
|
|
|
public void attack(Entity target) {
|
|
|
|
- if (target.isAttackable()) {
|
|
|
|
- if (!target.skipAttackInteraction(this)) {
|
|
|
|
+ // Paper start - PlayerAttackEntityEvent
|
|
|
|
+ boolean willAttack = target.isAttackable() && !target.skipAttackInteraction(this); // Vanilla logic
|
|
|
|
+ io.papermc.paper.event.player.PrePlayerAttackEntityEvent playerAttackEntityEvent = new io.papermc.paper.event.player.PrePlayerAttackEntityEvent(
|
|
|
|
+ (org.bukkit.entity.Player) this.getBukkitEntity(),
|
|
|
|
+ target.getBukkitEntity(),
|
|
|
|
+ willAttack
|
|
|
|
+ );
|
|
|
|
+
|
|
|
|
+ if (playerAttackEntityEvent.callEvent() && willAttack) { // Logic moved to willAttack local variable.
|
|
|
|
+ {
|
|
|
|
+ // Paper end
|
|
|
|
float f = (float) this.getAttributeValue(Attributes.ATTACK_DAMAGE);
|
|
|
|
float f1;
|
|
|
|
|