mirror of
https://github.com/PaperMC/Paper.git
synced 2025-01-01 13:57:35 +01:00
Properly Cancel Usable Items (#9225)
This fixes the bug causing canceling PlayerInteractEvent to cause items to continue to be used despite being canceled on the server. For example, items being consumed but never finishing, shields being put up, etc. The underlying issue of this is that the client modifies their synced data values, and so we have to (forcibly) resend them in order for the client to reset their using item state.
This commit is contained in:
parent
135469a842
commit
6a733d70c1
40
patches/server/Properly-Cancel-Usable-Items.patch
Normal file
40
patches/server/Properly-Cancel-Usable-Items.patch
Normal file
@ -0,0 +1,40 @@
|
|||||||
|
From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001
|
||||||
|
From: Owen1212055 <23108066+Owen1212055@users.noreply.github.com>
|
||||||
|
Date: Tue, 23 May 2023 22:33:36 -0400
|
||||||
|
Subject: [PATCH] Properly Cancel Usable Items
|
||||||
|
|
||||||
|
This fixes the bug causing cancelling PlayerInteractEvent to cause items to continue to be used despite being cancelled on the server.
|
||||||
|
|
||||||
|
For example, items being consumed but never finishing, shields being put up, etc.
|
||||||
|
The underlying issue of this is that the client modifies their synced data values, and so we have to (forcibly) resend
|
||||||
|
them in order for the client to reset their using item state.
|
||||||
|
|
||||||
|
diff --git a/src/main/java/net/minecraft/server/network/ServerGamePacketListenerImpl.java b/src/main/java/net/minecraft/server/network/ServerGamePacketListenerImpl.java
|
||||||
|
index 0000000000000000000000000000000000000000..0000000000000000000000000000000000000000 100644
|
||||||
|
--- a/src/main/java/net/minecraft/server/network/ServerGamePacketListenerImpl.java
|
||||||
|
+++ b/src/main/java/net/minecraft/server/network/ServerGamePacketListenerImpl.java
|
||||||
|
@@ -0,0 +0,0 @@ public class ServerGamePacketListenerImpl implements ServerPlayerConnection, Tic
|
||||||
|
}
|
||||||
|
|
||||||
|
if (cancelled) {
|
||||||
|
+ this.player.resyncUsingItem(this.player); // Paper - Resend player's using item status
|
||||||
|
this.player.getBukkitEntity().updateInventory(); // SPIGOT-2524
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
diff --git a/src/main/java/net/minecraft/world/entity/LivingEntity.java b/src/main/java/net/minecraft/world/entity/LivingEntity.java
|
||||||
|
index 0000000000000000000000000000000000000000..0000000000000000000000000000000000000000 100644
|
||||||
|
--- a/src/main/java/net/minecraft/world/entity/LivingEntity.java
|
||||||
|
+++ b/src/main/java/net/minecraft/world/entity/LivingEntity.java
|
||||||
|
@@ -0,0 +0,0 @@ public abstract class LivingEntity extends Entity implements Attackable {
|
||||||
|
return ((Byte) this.entityData.get(LivingEntity.DATA_LIVING_ENTITY_FLAGS) & 2) > 0 ? InteractionHand.OFF_HAND : InteractionHand.MAIN_HAND;
|
||||||
|
}
|
||||||
|
|
||||||
|
+ // Paper start
|
||||||
|
+ public void resyncUsingItem(ServerPlayer serverPlayer) {
|
||||||
|
+ this.getEntityData().resendPossiblyDesyncedDataValues(java.util.List.of(DATA_LIVING_ENTITY_FLAGS), serverPlayer);
|
||||||
|
+ }
|
||||||
|
+ // Paper end
|
||||||
|
+
|
||||||
|
// Paper start - lag compensate eating
|
||||||
|
protected long eatStartTime;
|
||||||
|
protected int totalEatTimeTicks;
|
@ -8,6 +8,8 @@ Entities that are interacted with need to be resent to the client, so we resend
|
|||||||
data to the player whilst making sure not to clear dirty entries from the tracker. This makes
|
data to the player whilst making sure not to clear dirty entries from the tracker. This makes
|
||||||
sure that values will be correctly updated to other players.
|
sure that values will be correctly updated to other players.
|
||||||
|
|
||||||
|
This also adds utilities to aid in further preventing entity desyncs.
|
||||||
|
|
||||||
See: https://github.com/PaperMC/Paper/pull/1896
|
See: https://github.com/PaperMC/Paper/pull/1896
|
||||||
|
|
||||||
== AT ==
|
== AT ==
|
||||||
@ -61,6 +63,20 @@ index 0000000000000000000000000000000000000000..00000000000000000000000000000000
|
|||||||
+ serverEntity.sendPairingData(player, player.connection::send);
|
+ serverEntity.sendPairingData(player, player.connection::send);
|
||||||
+ }
|
+ }
|
||||||
+ }
|
+ }
|
||||||
|
+
|
||||||
|
+ // This method allows you to specifically resend certain data accessor keys to the client
|
||||||
|
+ public void resendPossiblyDesyncedDataValues(List<EntityDataAccessor<?>> keys, ServerPlayer to) {
|
||||||
|
+ if (!to.getBukkitEntity().canSee(this.entity.getBukkitEntity())) {
|
||||||
|
+ return;
|
||||||
|
+ }
|
||||||
|
+ List<SynchedEntityData.DataValue<?>> values = new ArrayList<>(keys.size());
|
||||||
|
+ for (EntityDataAccessor<?> key : keys) {
|
||||||
|
+ SynchedEntityData.DataItem<?> synchedValue = this.getItem(key);
|
||||||
|
+ values.add(synchedValue.value());
|
||||||
|
+ }
|
||||||
|
+
|
||||||
|
+ to.connection.send(new ClientboundSetEntityDataPacket(this.entity.getId(), values));
|
||||||
|
+ }
|
||||||
+ // Paper end
|
+ // Paper end
|
||||||
|
|
||||||
public static class DataItem<T> {
|
public static class DataItem<T> {
|
||||||
|
Loading…
Reference in New Issue
Block a user