2023-03-19 19:58:34 +01:00
|
|
|
From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001
|
|
|
|
From: Jake Potrebic <jake.m.potrebic@gmail.com>
|
|
|
|
Date: Thu, 16 Mar 2023 10:04:17 +0100
|
|
|
|
Subject: [PATCH] Fix advancement triggers for entity damage
|
|
|
|
|
|
|
|
Changes the Interaction entity's trigger to use the vanilla
|
|
|
|
generic damage source
|
|
|
|
|
|
|
|
Fixes a couple places where the original damage and modified damage
|
|
|
|
were passed in the reverse order to the advancement triggers
|
|
|
|
|
|
|
|
diff --git a/src/main/java/net/minecraft/world/entity/Interaction.java b/src/main/java/net/minecraft/world/entity/Interaction.java
|
2024-10-24 00:32:21 +02:00
|
|
|
index 821bb93e1b055ba38fafe3b7079d79aa062ebe8a..221d73676fe2fd240a47cf312c1179e049298cac 100644
|
2023-03-19 19:58:34 +01:00
|
|
|
--- a/src/main/java/net/minecraft/world/entity/Interaction.java
|
|
|
|
+++ b/src/main/java/net/minecraft/world/entity/Interaction.java
|
2024-10-24 00:32:21 +02:00
|
|
|
@@ -159,7 +159,7 @@ public class Interaction extends Entity implements Attackable, Targeting {
|
2024-04-25 00:36:49 +02:00
|
|
|
// CraftBukkit end
|
|
|
|
this.attack = new Interaction.PlayerAction(entityhuman.getUUID(), this.level().getGameTime());
|
|
|
|
if (entityhuman instanceof ServerPlayer entityplayer) {
|
2023-03-19 19:58:34 +01:00
|
|
|
- CriteriaTriggers.PLAYER_HURT_ENTITY.trigger(entityplayer, this, source, (float) event.getFinalDamage(), 1.0F, false); // CraftBukkit
|
|
|
|
+ CriteriaTriggers.PLAYER_HURT_ENTITY.trigger(entityplayer, this, entityhuman.damageSources().generic(), 1.0F, (float) event.getFinalDamage(), false); // CraftBukkit // Paper - use correct source and fix taken/dealt param order
|
|
|
|
}
|
|
|
|
|
|
|
|
return !this.getResponse();
|
|
|
|
diff --git a/src/main/java/net/minecraft/world/entity/LivingEntity.java b/src/main/java/net/minecraft/world/entity/LivingEntity.java
|
2024-10-24 00:32:21 +02:00
|
|
|
index 447fb76a3eb1505b1ef1e1aed8a11239c0124f4f..95bbde31de42e1e12d722de86085e59050f1c3ae 100644
|
2023-03-19 19:58:34 +01:00
|
|
|
--- a/src/main/java/net/minecraft/world/entity/LivingEntity.java
|
|
|
|
+++ b/src/main/java/net/minecraft/world/entity/LivingEntity.java
|
2024-10-24 00:32:21 +02:00
|
|
|
@@ -2465,7 +2465,7 @@ public abstract class LivingEntity extends Entity implements Attackable {
|
2023-03-19 19:58:34 +01:00
|
|
|
// Duplicate triggers if blocking
|
|
|
|
if (event.getDamage(DamageModifier.BLOCKING) < 0) {
|
|
|
|
if (this instanceof ServerPlayer) {
|
|
|
|
- CriteriaTriggers.ENTITY_HURT_PLAYER.trigger((ServerPlayer) this, damagesource, f, originalDamage, true);
|
|
|
|
+ CriteriaTriggers.ENTITY_HURT_PLAYER.trigger((ServerPlayer) this, damagesource, originalDamage, f, true); // Paper - fix taken/dealt param order
|
|
|
|
f2 = (float) -event.getDamage(DamageModifier.BLOCKING);
|
|
|
|
if (f2 > 0.0F && f2 < 3.4028235E37F) {
|
|
|
|
((ServerPlayer) this).awardStat(Stats.DAMAGE_BLOCKED_BY_SHIELD, Math.round(originalDamage * 10.0F));
|
2024-10-24 00:32:21 +02:00
|
|
|
@@ -2473,7 +2473,7 @@ public abstract class LivingEntity extends Entity implements Attackable {
|
2023-03-19 19:58:34 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
if (damagesource.getEntity() instanceof ServerPlayer) {
|
|
|
|
- CriteriaTriggers.PLAYER_HURT_ENTITY.trigger((ServerPlayer) damagesource.getEntity(), this, damagesource, f, originalDamage, true);
|
|
|
|
+ CriteriaTriggers.PLAYER_HURT_ENTITY.trigger((ServerPlayer) damagesource.getEntity(), this, damagesource, originalDamage, f, true); // Paper - fix taken/dealt param order
|
|
|
|
}
|
|
|
|
|
2024-04-28 03:00:01 +02:00
|
|
|
return true;
|