2020-05-06 09:48:49 +00:00
From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001
2020-03-27 03:04:19 +00:00
From: nossr50 <nossr50@gmail.com>
Date: Thu, 26 Mar 2020 19:44:50 -0700
Subject: [PATCH] Add PlayerAttackEntityCooldownResetEvent
2021-03-16 07:19:45 +00:00
diff --git a/src/main/java/net/minecraft/world/entity/EntityLiving.java b/src/main/java/net/minecraft/world/entity/EntityLiving.java
2021-03-16 13:04:28 +00:00
index b33f57bc72333a2fee785cb95eb6be09892b136d..f2721cf55dd8edc7376b27250f83029e2b3b4e93 100644
2021-03-16 07:19:45 +00:00
--- a/src/main/java/net/minecraft/world/entity/EntityLiving.java
+++ b/src/main/java/net/minecraft/world/entity/EntityLiving.java
2021-03-16 13:04:28 +00:00
@@ -1931,7 +1931,16 @@ public abstract class EntityLiving extends Entity {
2020-03-27 03:04:19 +00:00
2020-04-27 07:34:45 +00:00
EntityDamageEvent event = CraftEventFactory.handleLivingEntityDamageEvent(this, damagesource, originalDamage, hardHatModifier, blockingModifier, armorModifier, resistanceModifier, magicModifier, absorptionModifier, hardHat, blocking, armor, resistance, magic, absorption);
if (damagesource.getEntity() instanceof EntityHuman) {
2020-06-26 01:53:21 +00:00
- ((EntityHuman) damagesource.getEntity()).resetAttackCooldown(); // Moved from EntityHuman in order to make the cooldown reset get called after the damage event is fired
2020-03-27 03:04:19 +00:00
+ // Paper start - PlayerAttackEntityCooldownResetEvent
2020-04-27 07:34:45 +00:00
+ if (damagesource.getEntity() instanceof EntityPlayer) {
+ EntityPlayer player = (EntityPlayer) damagesource.getEntity();
2020-08-02 05:39:36 +00:00
+ if (new com.destroystokyo.paper.event.player.PlayerAttackEntityCooldownResetEvent(player.getBukkitEntity(), this.getBukkitEntity(), player.getAttackCooldown(0F)).callEvent()) {
+ player.resetAttackCooldown();
2020-04-27 07:34:45 +00:00
+ }
+ } else {
2020-08-02 05:39:36 +00:00
+ ((EntityHuman) damagesource.getEntity()).resetAttackCooldown();
2020-03-27 03:04:19 +00:00
+ }
+ // Paper end
2020-04-27 07:34:45 +00:00
}
if (event.isCancelled()) {
return false;