Minestom/src/main/java/net/minestom/server/network/packet/server/play/EntityEquipmentPacket.java

78 lines
2.8 KiB
Java
Raw Normal View History

2020-04-24 03:25:58 +02:00
package net.minestom.server.network.packet.server.play;
2019-08-20 22:40:57 +02:00
import net.kyori.adventure.text.Component;
import net.minestom.server.entity.EquipmentSlot;
2020-04-24 03:25:58 +02:00
import net.minestom.server.item.ItemStack;
2022-10-29 11:02:22 +02:00
import net.minestom.server.network.NetworkBuffer;
2024-03-19 17:42:06 +01:00
import net.minestom.server.network.packet.server.ServerPacket.ComponentHolding;
2020-04-24 03:25:58 +02:00
import net.minestom.server.network.packet.server.ServerPacket;
import net.minestom.server.network.packet.server.ServerPacketIdentifier;
import org.jetbrains.annotations.NotNull;
2019-08-20 22:40:57 +02:00
import java.util.Collection;
2021-11-30 17:49:41 +01:00
import java.util.EnumMap;
import java.util.Map;
import java.util.Objects;
import java.util.function.UnaryOperator;
import java.util.stream.Collectors;
2022-10-29 11:02:22 +02:00
import static net.minestom.server.network.NetworkBuffer.*;
public record EntityEquipmentPacket(int entityId,
2024-03-19 17:42:06 +01:00
@NotNull Map<EquipmentSlot, ItemStack> equipments) implements ServerPacket.Play, ServerPacket.ComponentHolding {
2021-11-30 17:49:41 +01:00
public EntityEquipmentPacket {
equipments = Map.copyOf(equipments);
if (equipments.isEmpty())
throw new IllegalArgumentException("Equipments cannot be empty");
2021-11-30 17:49:41 +01:00
}
2019-08-20 22:40:57 +02:00
2022-10-29 11:02:22 +02:00
public EntityEquipmentPacket(@NotNull NetworkBuffer reader) {
this(reader.read(VAR_INT), readEquipments(reader));
2021-04-02 18:13:02 +02:00
}
2019-08-20 22:40:57 +02:00
@Override
2022-10-29 11:02:22 +02:00
public void write(@NotNull NetworkBuffer writer) {
writer.write(VAR_INT, entityId);
2021-11-30 17:49:41 +01:00
int index = 0;
for (var entry : equipments.entrySet()) {
final boolean last = index++ == equipments.size() - 1;
byte slotEnum = (byte) entry.getKey().ordinal();
if (!last) slotEnum |= 0x80;
2022-10-29 11:02:22 +02:00
writer.write(BYTE, slotEnum);
writer.write(ITEM, entry.getValue());
2020-08-10 13:55:06 +02:00
}
2019-08-20 22:40:57 +02:00
}
@Override
2024-03-19 17:42:06 +01:00
public int playId() {
return ServerPacketIdentifier.ENTITY_EQUIPMENT;
2021-11-30 17:49:41 +01:00
}
@Override
public @NotNull Collection<Component> components() {
return this.equipments.values()
.stream()
.map(ItemStack::getDisplayName)
.filter(Objects::nonNull)
.collect(Collectors.toList());
}
@Override
public @NotNull ServerPacket copyWithOperator(@NotNull UnaryOperator<Component> operator) {
final var map = new EnumMap<EquipmentSlot, ItemStack>(EquipmentSlot.class);
this.equipments.forEach((key, value) -> map.put(key, value.withDisplayName(operator)));
return new EntityEquipmentPacket(this.entityId, map);
}
2022-10-29 11:02:22 +02:00
private static Map<EquipmentSlot, ItemStack> readEquipments(@NotNull NetworkBuffer reader) {
Map<EquipmentSlot, ItemStack> equipments = new EnumMap<>(EquipmentSlot.class);
byte slot;
do {
2022-10-29 11:02:22 +02:00
slot = reader.read(BYTE);
equipments.put(EquipmentSlot.values()[slot & 0x7F], reader.read(ITEM));
} while ((slot & 0x80) == 0x80);
2021-11-30 17:49:41 +01:00
return equipments;
2019-08-20 22:40:57 +02:00
}
}