diff --git a/paper-server/src/main/java/org/bukkit/craftbukkit/inventory/CraftMetaItem.java b/paper-server/src/main/java/org/bukkit/craftbukkit/inventory/CraftMetaItem.java index bb764444b5..09e2d246ce 100644 --- a/paper-server/src/main/java/org/bukkit/craftbukkit/inventory/CraftMetaItem.java +++ b/paper-server/src/main/java/org/bukkit/craftbukkit/inventory/CraftMetaItem.java @@ -224,6 +224,7 @@ class CraftMetaItem implements ItemMeta, Repairable { private static final Set HANDLED_TAGS = Sets.newHashSet(); + private NBTTagCompound internalTag; private final Map unhandledTags = new HashMap(); CraftMetaItem(CraftMetaItem meta) { @@ -245,6 +246,11 @@ class CraftMetaItem implements ItemMeta, Repairable { this.hideFlag = meta.hideFlag; this.unbreakable = meta.unbreakable; this.unhandledTags.putAll(meta.unhandledTags); + + this.internalTag = meta.internalTag; + if (this.internalTag != null) { + deserializeInternal(internalTag); + } } CraftMetaItem(NBTTagCompound tag) { @@ -388,12 +394,12 @@ class CraftMetaItem implements ItemMeta, Repairable { if (internal != null) { ByteArrayInputStream buf = new ByteArrayInputStream(Base64.decodeBase64(internal)); try { - NBTTagCompound tag = NBTCompressedStreamTools.a(buf); - deserializeInternal(tag); - Set keys = tag.c(); + internalTag = NBTCompressedStreamTools.a(buf); + deserializeInternal(internalTag); + Set keys = internalTag.c(); for (String key : keys) { if (!getHandledTags().contains(key)) { - unhandledTags.put(key, tag.get(key)); + unhandledTags.put(key, internalTag.get(key)); } } } catch (IOException ex) { diff --git a/paper-server/src/main/java/org/bukkit/craftbukkit/inventory/CraftMetaSpawnEgg.java b/paper-server/src/main/java/org/bukkit/craftbukkit/inventory/CraftMetaSpawnEgg.java index 22199ed7e7..b98c02ff1e 100644 --- a/paper-server/src/main/java/org/bukkit/craftbukkit/inventory/CraftMetaSpawnEgg.java +++ b/paper-server/src/main/java/org/bukkit/craftbukkit/inventory/CraftMetaSpawnEgg.java @@ -3,7 +3,9 @@ package org.bukkit.craftbukkit.inventory; import com.google.common.base.Preconditions; import com.google.common.collect.ImmutableMap.Builder; import java.util.Map; +import net.minecraft.server.DataConverterTypes; import net.minecraft.server.MinecraftKey; +import net.minecraft.server.MinecraftServer; import net.minecraft.server.NBTTagCompound; import org.bukkit.Material; import org.bukkit.configuration.serialization.DelegateDeserialization; @@ -50,6 +52,20 @@ public class CraftMetaSpawnEgg extends CraftMetaItem implements SpawnEggMeta { setSpawnedType(EntityType.fromName(entityType)); } + @Override + void deserializeInternal(NBTTagCompound tag) { + super.deserializeInternal(tag); + + if (tag.hasKey(ENTITY_TAG.NBT)) { + entityTag = tag.getCompound(ENTITY_TAG.NBT); + MinecraftServer.getServer().getDataConverterManager().a(DataConverterTypes.ENTITY, entityTag); // PAIL: convert + + if (entityTag.hasKey(ENTITY_ID.NBT)) { + this.spawnedType = EntityType.fromName(new MinecraftKey(entityTag.getString(ENTITY_ID.NBT)).a()); // PAIL: rename + } + } + } + @Override void applyToItem(NBTTagCompound tag) { super.applyToItem(tag);