2021-12-04 14:10:57 +00:00
|
|
|
From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001
|
|
|
|
From: SamB440 <sam@islandearth.net>
|
|
|
|
Date: Wed, 17 Nov 2021 12:31:42 +0000
|
|
|
|
Subject: [PATCH] Add player health update API
|
|
|
|
|
|
|
|
|
|
|
|
diff --git a/src/main/java/org/bukkit/craftbukkit/entity/CraftPlayer.java b/src/main/java/org/bukkit/craftbukkit/entity/CraftPlayer.java
|
2022-12-07 21:35:34 +00:00
|
|
|
index ea2316ffa7b494f3f5f102b44fc8d3ec6d9a4131..10ff3f8aba814d73af931e6c91ea9a2c421592bf 100644
|
2021-12-04 14:10:57 +00:00
|
|
|
--- a/src/main/java/org/bukkit/craftbukkit/entity/CraftPlayer.java
|
|
|
|
+++ b/src/main/java/org/bukkit/craftbukkit/entity/CraftPlayer.java
|
2022-12-07 21:35:34 +00:00
|
|
|
@@ -2227,9 +2227,11 @@ public class CraftPlayer extends CraftHumanEntity implements Player {
|
2021-12-04 14:10:57 +00:00
|
|
|
this.getHandle().maxHealthCache = getMaxHealth();
|
|
|
|
}
|
|
|
|
|
|
|
|
- public void sendHealthUpdate() {
|
|
|
|
+ // Paper start
|
|
|
|
+ @Override
|
|
|
|
+ public void sendHealthUpdate(final double health, final int foodLevel, final float saturationLevel) {
|
|
|
|
// Paper start - cancellable death event
|
|
|
|
- ClientboundSetHealthPacket packet = new ClientboundSetHealthPacket(this.getScaledHealth(), this.getHandle().getFoodData().getFoodLevel(), this.getHandle().getFoodData().getSaturationLevel());
|
|
|
|
+ ClientboundSetHealthPacket packet = new ClientboundSetHealthPacket((float) health, foodLevel, saturationLevel);
|
|
|
|
if (this.getHandle().queueHealthUpdatePacket) {
|
|
|
|
this.getHandle().queuedHealthUpdatePacket = packet;
|
|
|
|
} else {
|
2022-12-07 21:35:34 +00:00
|
|
|
@@ -2237,7 +2239,13 @@ public class CraftPlayer extends CraftHumanEntity implements Player {
|
2021-12-04 14:10:57 +00:00
|
|
|
}
|
|
|
|
// Paper end
|
|
|
|
}
|
|
|
|
-
|
|
|
|
+
|
|
|
|
+ @Override
|
|
|
|
+ public void sendHealthUpdate() {
|
|
|
|
+ this.sendHealthUpdate(this.getScaledHealth(), this.getHandle().getFoodData().getFoodLevel(), this.getHandle().getFoodData().getSaturationLevel());
|
|
|
|
+ }
|
|
|
|
+ // Paper end
|
|
|
|
+
|
|
|
|
public void injectScaledMaxHealth(Collection<AttributeInstance> collection, boolean force) {
|
|
|
|
if (!this.scaledHealth && !force) {
|
|
|
|
return;
|