mirror of
https://github.com/Minestom/Minestom.git
synced 2025-01-08 01:17:47 +01:00
Fix tags packet
This commit is contained in:
parent
72bf894162
commit
265ae83b4d
@ -291,17 +291,8 @@ public class Player extends LivingEntity implements CommandSender, Localizable,
|
|||||||
}
|
}
|
||||||
// Recipes end
|
// Recipes end
|
||||||
|
|
||||||
// Tags start
|
// Tags
|
||||||
{
|
this.playerConnection.sendPacket(TagsPacket.getRequiredTagsPacket());
|
||||||
TagsPacket tags = TagsPacket.getRequiredTagsPacket();
|
|
||||||
|
|
||||||
UpdateTagListEvent event = new UpdateTagListEvent(tags);
|
|
||||||
callEvent(UpdateTagListEvent.class, event);
|
|
||||||
|
|
||||||
// TODO send tags
|
|
||||||
this.playerConnection.sendPacket(tags);
|
|
||||||
}
|
|
||||||
// Tags end
|
|
||||||
|
|
||||||
// Some client update
|
// Some client update
|
||||||
this.playerConnection.sendPacket(getPropertiesPacket()); // Send default properties
|
this.playerConnection.sendPacket(getPropertiesPacket()); // Send default properties
|
||||||
|
@ -4,6 +4,7 @@ import net.minestom.server.event.Event;
|
|||||||
import net.minestom.server.network.packet.server.play.TagsPacket;
|
import net.minestom.server.network.packet.server.play.TagsPacket;
|
||||||
import org.jetbrains.annotations.NotNull;
|
import org.jetbrains.annotations.NotNull;
|
||||||
|
|
||||||
|
@Deprecated
|
||||||
public class UpdateTagListEvent extends Event {
|
public class UpdateTagListEvent extends Event {
|
||||||
|
|
||||||
private TagsPacket packet;
|
private TagsPacket packet;
|
||||||
|
@ -2,10 +2,8 @@ package net.minestom.server.network.packet.server.play;
|
|||||||
|
|
||||||
import net.minestom.server.MinecraftServer;
|
import net.minestom.server.MinecraftServer;
|
||||||
import net.minestom.server.entity.EntityType;
|
import net.minestom.server.entity.EntityType;
|
||||||
import net.minestom.server.fluid.Fluid;
|
|
||||||
import net.minestom.server.gamedata.tags.Tag;
|
import net.minestom.server.gamedata.tags.Tag;
|
||||||
import net.minestom.server.instance.block.Block;
|
import net.minestom.server.instance.block.Block;
|
||||||
import net.minestom.server.item.Material;
|
|
||||||
import net.minestom.server.network.packet.server.ServerPacket;
|
import net.minestom.server.network.packet.server.ServerPacket;
|
||||||
import net.minestom.server.network.packet.server.ServerPacketIdentifier;
|
import net.minestom.server.network.packet.server.ServerPacketIdentifier;
|
||||||
import net.minestom.server.registry.Registries;
|
import net.minestom.server.registry.Registries;
|
||||||
@ -14,7 +12,10 @@ import net.minestom.server.utils.binary.BinaryReader;
|
|||||||
import net.minestom.server.utils.binary.BinaryWriter;
|
import net.minestom.server.utils.binary.BinaryWriter;
|
||||||
import org.jetbrains.annotations.NotNull;
|
import org.jetbrains.annotations.NotNull;
|
||||||
|
|
||||||
import java.util.*;
|
import java.util.HashMap;
|
||||||
|
import java.util.List;
|
||||||
|
import java.util.Map;
|
||||||
|
import java.util.Set;
|
||||||
|
|
||||||
public class TagsPacket implements ServerPacket {
|
public class TagsPacket implements ServerPacket {
|
||||||
|
|
||||||
@ -35,13 +36,13 @@ public class TagsPacket implements ServerPacket {
|
|||||||
@Override
|
@Override
|
||||||
public void write(@NotNull BinaryWriter writer) {
|
public void write(@NotNull BinaryWriter writer) {
|
||||||
writer.writeVarInt(tagsMap.size());
|
writer.writeVarInt(tagsMap.size());
|
||||||
for (Tag.BasicTypes type : Tag.BasicTypes.values()) {
|
for (var entry : tagsMap.entrySet()) {
|
||||||
switch (type) {
|
final var type = entry.getKey();
|
||||||
case BLOCKS: {
|
final var tags = entry.getValue();
|
||||||
List<Tag> tags = tagsMap.get(type);
|
|
||||||
|
|
||||||
// Tag type
|
// Tag type
|
||||||
writer.writeSizedString(type.getIdentifier());
|
writer.writeSizedString(type.getIdentifier());
|
||||||
|
switch (type) {
|
||||||
|
case BLOCKS: {
|
||||||
// Number of tags
|
// Number of tags
|
||||||
writer.writeVarInt(tags.size());
|
writer.writeVarInt(tags.size());
|
||||||
for (Tag tag : tags) {
|
for (Tag tag : tags) {
|
||||||
@ -62,11 +63,6 @@ public class TagsPacket implements ServerPacket {
|
|||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
case ENTITY_TYPES: {
|
case ENTITY_TYPES: {
|
||||||
List<Tag> tags = tagsMap.get(type);
|
|
||||||
|
|
||||||
// Tag type
|
|
||||||
writer.writeSizedString(type.getIdentifier());
|
|
||||||
|
|
||||||
// Number of tags
|
// Number of tags
|
||||||
writer.writeVarInt(tags.size());
|
writer.writeVarInt(tags.size());
|
||||||
for (Tag tag : tags) {
|
for (Tag tag : tags) {
|
||||||
@ -89,11 +85,6 @@ public class TagsPacket implements ServerPacket {
|
|||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
case FLUIDS: {
|
case FLUIDS: {
|
||||||
List<Tag> tags = tagsMap.get(type);
|
|
||||||
|
|
||||||
// Tag type
|
|
||||||
writer.writeSizedString(type.getIdentifier());
|
|
||||||
|
|
||||||
// Number of tags
|
// Number of tags
|
||||||
writer.writeVarInt(tags.size());
|
writer.writeVarInt(tags.size());
|
||||||
for (Tag tag : tags) {
|
for (Tag tag : tags) {
|
||||||
@ -111,11 +102,6 @@ public class TagsPacket implements ServerPacket {
|
|||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
case GAME_EVENTS: {
|
case GAME_EVENTS: {
|
||||||
List<Tag> tags = tagsMap.get(type);
|
|
||||||
|
|
||||||
// Tag type
|
|
||||||
writer.writeSizedString(type.getIdentifier());
|
|
||||||
|
|
||||||
// Number of tags
|
// Number of tags
|
||||||
writer.writeVarInt(tags.size());
|
writer.writeVarInt(tags.size());
|
||||||
for (Tag tag : tags) {
|
for (Tag tag : tags) {
|
||||||
@ -134,11 +120,6 @@ public class TagsPacket implements ServerPacket {
|
|||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
case ITEMS: {
|
case ITEMS: {
|
||||||
List<Tag> tags = tagsMap.get(type);
|
|
||||||
|
|
||||||
// Tag type
|
|
||||||
writer.writeSizedString(type.getIdentifier());
|
|
||||||
|
|
||||||
// Number of tags
|
// Number of tags
|
||||||
writer.writeVarInt(tags.size());
|
writer.writeVarInt(tags.size());
|
||||||
for (Tag tag : tags) {
|
for (Tag tag : tags) {
|
||||||
@ -170,118 +151,12 @@ public class TagsPacket implements ServerPacket {
|
|||||||
if (tagType == null) {
|
if (tagType == null) {
|
||||||
throw new IllegalArgumentException("Tag type could not be resolved");
|
throw new IllegalArgumentException("Tag type could not be resolved");
|
||||||
}
|
}
|
||||||
switch (tagType) {
|
|
||||||
case BLOCKS: {
|
|
||||||
// Read tag ID
|
|
||||||
final String identifier = reader.readSizedString(Integer.MAX_VALUE);
|
|
||||||
List<Tag> tags = new ArrayList<>();
|
|
||||||
// Read amount of tags
|
|
||||||
final int tagCount = reader.readVarInt();
|
|
||||||
Set<NamespaceID> values = new HashSet<>();
|
|
||||||
// Read tags
|
|
||||||
for (int j = 0; j < tagCount; j++) {
|
|
||||||
int protocolID = reader.readVarInt();
|
|
||||||
Block b = Block.fromId((short) protocolID);
|
|
||||||
if (b == null) {
|
|
||||||
throw new IllegalArgumentException("Block with id '" + protocolID + "' could not be resolved for a tag.");
|
|
||||||
} else {
|
|
||||||
values.add(NamespaceID.from(b.getName()));
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
tags.add(new Tag(NamespaceID.from(identifier), values));
|
|
||||||
this.tagsMap.put(Tag.BasicTypes.BLOCKS, tags);
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
case ENTITY_TYPES: {
|
|
||||||
// Read tag ID
|
|
||||||
final String identifier = reader.readSizedString(Integer.MAX_VALUE);
|
|
||||||
List<Tag> tags = new ArrayList<>();
|
|
||||||
// Read amount of tags
|
|
||||||
final int tagCount = reader.readVarInt();
|
final int tagCount = reader.readVarInt();
|
||||||
Set<NamespaceID> values = new HashSet<>();
|
|
||||||
// Read tags
|
|
||||||
for (int j = 0; j < tagCount; j++) {
|
for (int j = 0; j < tagCount; j++) {
|
||||||
int protocolID = reader.readVarInt();
|
final String tagName = reader.readSizedString(Integer.MAX_VALUE);
|
||||||
EntityType et = EntityType.fromId((short) protocolID);
|
final int[] entries = reader.readVarIntArray();
|
||||||
if (et == null) {
|
// TODO convert
|
||||||
throw new IllegalArgumentException("Entity type with id '" + protocolID + "' could not be resolved for a tag.");
|
|
||||||
} else {
|
|
||||||
values.add(et.getNamespaceID());
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
tags.add(new Tag(NamespaceID.from(identifier), values));
|
|
||||||
this.tagsMap.put(Tag.BasicTypes.ENTITY_TYPES, tags);
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
case FLUIDS: {
|
|
||||||
// Read tag ID
|
|
||||||
final String identifier = reader.readSizedString(Integer.MAX_VALUE);
|
|
||||||
List<Tag> tags = new ArrayList<>();
|
|
||||||
// Read amount of tags
|
|
||||||
final int tagCount = reader.readVarInt();
|
|
||||||
Set<NamespaceID> values = new HashSet<>();
|
|
||||||
// Read tags
|
|
||||||
for (int j = 0; j < tagCount; j++) {
|
|
||||||
int protocolID = reader.readVarInt();
|
|
||||||
Fluid f = Fluid.fromId((short) protocolID);
|
|
||||||
if (f == null) {
|
|
||||||
throw new IllegalArgumentException("Fluid with id '" + protocolID + "' could not be resolved for a tag.");
|
|
||||||
} else {
|
|
||||||
values.add(f.getNamespaceID());
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
tags.add(new Tag(NamespaceID.from(identifier), values));
|
|
||||||
this.tagsMap.put(Tag.BasicTypes.FLUIDS, tags);
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
case GAME_EVENTS: {
|
|
||||||
// Read tag ID
|
|
||||||
final String identifier = reader.readSizedString(Integer.MAX_VALUE);
|
|
||||||
List<Tag> tags = new ArrayList<>();
|
|
||||||
// Read amount of tags
|
|
||||||
final int tagCount = reader.readVarInt();
|
|
||||||
Set<NamespaceID> values = new HashSet<>();
|
|
||||||
// Read tags
|
|
||||||
for (int j = 0; j < tagCount; j++) {
|
|
||||||
int protocolID = reader.readVarInt();
|
|
||||||
// TODO: GameEvent
|
|
||||||
// GameEvent ge = GameEvent.fromId((short) protocolID);
|
|
||||||
// if (ge == null) {
|
|
||||||
// throw new IllegalArgumentException("Game event with id '" + protocolID + "' could not be resolved for a tag.");
|
|
||||||
// } else {
|
|
||||||
// values.add(ge.getNamespaceID());
|
|
||||||
// }
|
|
||||||
}
|
|
||||||
|
|
||||||
tags.add(new Tag(NamespaceID.from(identifier), values));
|
|
||||||
this.tagsMap.put(Tag.BasicTypes.GAME_EVENTS, tags);
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
case ITEMS: {
|
|
||||||
// Read tag ID
|
|
||||||
final String identifier = reader.readSizedString(Integer.MAX_VALUE);
|
|
||||||
List<Tag> tags = new ArrayList<>();
|
|
||||||
// Read amount of tags
|
|
||||||
final int tagCount = reader.readVarInt();
|
|
||||||
Set<NamespaceID> values = new HashSet<>();
|
|
||||||
// Read tags
|
|
||||||
for (int j = 0; j < tagCount; j++) {
|
|
||||||
int protocolID = reader.readVarInt();
|
|
||||||
Material m = Material.fromId((short) protocolID);
|
|
||||||
if (m == null) {
|
|
||||||
throw new IllegalArgumentException("Item with id '" + protocolID + "' could not be resolved for a tag.");
|
|
||||||
} else {
|
|
||||||
values.add(m.getNamespaceID());
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
tags.add(new Tag(NamespaceID.from(identifier), values));
|
|
||||||
this.tagsMap.put(Tag.BasicTypes.ITEMS, tags);
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user