From 6e0f8f99fa2b4c2cb2fc3b0a818fb439177afa62 Mon Sep 17 00:00:00 2001 From: nossr50 Date: Tue, 1 Oct 2019 15:44:58 -0700 Subject: [PATCH] Progress? --- .../gmail/nossr50/util/nbt/NBTManager.java | 19 ++++++++++++++++--- 1 file changed, 16 insertions(+), 3 deletions(-) diff --git a/mcmmo-core/src/main/java/com/gmail/nossr50/util/nbt/NBTManager.java b/mcmmo-core/src/main/java/com/gmail/nossr50/util/nbt/NBTManager.java index aa3da4416..87916ad46 100644 --- a/mcmmo-core/src/main/java/com/gmail/nossr50/util/nbt/NBTManager.java +++ b/mcmmo-core/src/main/java/com/gmail/nossr50/util/nbt/NBTManager.java @@ -12,6 +12,9 @@ import org.bukkit.entity.Player; import org.bukkit.inventory.ItemStack; import org.checkerframework.checker.nullness.qual.Nullable; +import java.lang.reflect.InvocationTargetException; +import java.lang.reflect.Method; + public class NBTManager { private static final String CRAFT_META_ITEM_CLASS_PATH = "org.bukkit.craftbukkit.inventory.CraftMetaItem"; @@ -58,9 +61,19 @@ public class NBTManager { public static ItemStack saveNBT(ItemStack itemStack, NBTTagCompound nbtTagCompound) { net.minecraft.server.v1_14_R1.ItemStack nmsItemStack = getNMSItemStack(itemStack); - nmsItemStack.save(nbtTagCompound); - CraftItemStack craftItemStack = CraftItemStack.asCraftMirror(nmsItemStack); - itemStack.setItemMeta(craftItemStack.getItemMeta()); + + try { + Class clazz = Class.forName("net.minecraft.server.v1_14_R1.ItemStack"); + Class[] methodParameters = new Class[]{ NBTTagCompound.class }; + Method loadMethod = clazz.getDeclaredMethod("load", methodParameters); + loadMethod.setAccessible(true); + loadMethod.invoke(nmsItemStack, nbtTagCompound); + } catch (ClassNotFoundException | NoSuchMethodException | InvocationTargetException | IllegalAccessException e) { + e.printStackTrace(); + } + +// nmsItemStack.save(nbtTagCompound); +// itemStack.setItemMeta(nmsItemStack..getItemMeta()); return itemStack; }