From 229f3bb810baf2652890e98ab9e778b0a27d97cb Mon Sep 17 00:00:00 2001 From: CraftBukkit/Spigot Date: Mon, 27 Feb 2023 20:27:47 +1100 Subject: [PATCH] #1140: Add a method to send multiple equipment changes By: Parker Hawke --- .../craftbukkit/entity/CraftPlayer.java | 22 ++++++++++++++----- 1 file changed, 16 insertions(+), 6 deletions(-) diff --git a/paper-server/src/main/java/org/bukkit/craftbukkit/entity/CraftPlayer.java b/paper-server/src/main/java/org/bukkit/craftbukkit/entity/CraftPlayer.java index e7c001d495..7bfea1927b 100644 --- a/paper-server/src/main/java/org/bukkit/craftbukkit/entity/CraftPlayer.java +++ b/paper-server/src/main/java/org/bukkit/craftbukkit/entity/CraftPlayer.java @@ -724,15 +724,25 @@ public class CraftPlayer extends CraftHumanEntity implements Player { @Override public void sendEquipmentChange(LivingEntity entity, EquipmentSlot slot, ItemStack item) { + this.sendEquipmentChange(entity, Map.of(slot, item)); + } + + @Override + public void sendEquipmentChange(LivingEntity entity, Map items) { Preconditions.checkArgument(entity != null, "entity must not be null"); - Preconditions.checkArgument(slot != null, "slot must not be null"); - Preconditions.checkArgument(item != null, "item must not be null"); + Preconditions.checkArgument(items != null, "items must not be null"); - if (getHandle().connection == null) return; + if (getHandle().connection == null) { + return; + } - List> equipment = Arrays.asList( - new Pair<>(CraftEquipmentSlot.getNMS(slot), CraftItemStack.asNMSCopy(item)) - ); + List> equipment = new ArrayList<>(items.size()); + for (Map.Entry entry : items.entrySet()) { + EquipmentSlot slot = entry.getKey(); + Preconditions.checkArgument(slot != null, "Cannot set null EquipmentSlot"); + + equipment.add(new Pair<>(CraftEquipmentSlot.getNMS(slot), CraftItemStack.asNMSCopy(entry.getValue()))); + } getHandle().connection.send(new PacketPlayOutEntityEquipment(entity.getEntityId(), equipment)); }