mirror of
https://github.com/PaperMC/Paper.git
synced 2025-01-01 17:01:56 +01:00
Process NMS Data Conversion post ItemMeta on Copy
ItemMeta apply is a destructive process that expects to be the authority on what the items NBT data is. When CraftItemStack.asNMSCopy was called, the conversion ran, potentially setting the converted data into the ItemStacks tag. Then if that item had ItemMeta, it would completely undo that conversion by erasing the NBT Tag. On copy, run conversion post ItemMeta apply.
This commit is contained in:
parent
cc1f66ce0e
commit
d330ae5050
1 changed files with 63 additions and 0 deletions
|
@ -0,0 +1,63 @@
|
||||||
|
From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001
|
||||||
|
From: Aikar <aikar@aikar.co>
|
||||||
|
Date: Wed, 4 May 2016 22:31:18 -0400
|
||||||
|
Subject: [PATCH] Process NMS Data Conversion post ItemMeta on Copy
|
||||||
|
|
||||||
|
ItemMeta apply is a destructive process that expects to be the authority on
|
||||||
|
what the items NBT data is.
|
||||||
|
|
||||||
|
When CraftItemStack.asNMSCopy was called, the conversion ran, potentially setting
|
||||||
|
the converted data into the ItemStacks tag.
|
||||||
|
|
||||||
|
Then if that item had ItemMeta, it would completely undo that conversion by
|
||||||
|
erasing the NBT Tag.
|
||||||
|
|
||||||
|
On copy, run conversion post ItemMeta apply.
|
||||||
|
|
||||||
|
diff --git a/src/main/java/net/minecraft/server/ItemStack.java b/src/main/java/net/minecraft/server/ItemStack.java
|
||||||
|
index 0000000000000000000000000000000000000000..0000000000000000000000000000000000000000 100644
|
||||||
|
--- a/src/main/java/net/minecraft/server/ItemStack.java
|
||||||
|
+++ b/src/main/java/net/minecraft/server/ItemStack.java
|
||||||
|
@@ -0,0 +0,0 @@ public final class ItemStack {
|
||||||
|
this(item, i, 0);
|
||||||
|
}
|
||||||
|
|
||||||
|
+ // Paper start
|
||||||
|
public ItemStack(Item item, int i, int j) {
|
||||||
|
+ this(item, i, j, true);
|
||||||
|
+ }
|
||||||
|
+ public ItemStack(Item item, int i, int j, boolean convert) {
|
||||||
|
+ // Paper end
|
||||||
|
this.item = item;
|
||||||
|
this.count = i;
|
||||||
|
|
||||||
|
@@ -0,0 +0,0 @@ public final class ItemStack {
|
||||||
|
//if (this.damage < 0) {
|
||||||
|
// this.damage = 0;
|
||||||
|
//}
|
||||||
|
+ // Paper start
|
||||||
|
+ if (convert) convertData();
|
||||||
|
+ }
|
||||||
|
+ public final void convertData() {
|
||||||
|
+ // Paper end
|
||||||
|
if (MinecraftServer.getServer() != null) {
|
||||||
|
NBTTagCompound savedStack = new NBTTagCompound();
|
||||||
|
this.save(savedStack);
|
||||||
|
diff --git a/src/main/java/org/bukkit/craftbukkit/inventory/CraftItemStack.java b/src/main/java/org/bukkit/craftbukkit/inventory/CraftItemStack.java
|
||||||
|
index 0000000000000000000000000000000000000000..0000000000000000000000000000000000000000 100644
|
||||||
|
--- a/src/main/java/org/bukkit/craftbukkit/inventory/CraftItemStack.java
|
||||||
|
+++ b/src/main/java/org/bukkit/craftbukkit/inventory/CraftItemStack.java
|
||||||
|
@@ -0,0 +0,0 @@ public final class CraftItemStack extends ItemStack {
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
|
||||||
|
- net.minecraft.server.ItemStack stack = new net.minecraft.server.ItemStack(item, original.getAmount(), original.getDurability());
|
||||||
|
+ net.minecraft.server.ItemStack stack = new net.minecraft.server.ItemStack(item, original.getAmount(), original.getDurability(), false); // Paper
|
||||||
|
if (original.hasItemMeta()) {
|
||||||
|
setItemMeta(stack, original.getItemMeta());
|
||||||
|
}
|
||||||
|
+ stack.convertData(); // Paper
|
||||||
|
return stack;
|
||||||
|
}
|
||||||
|
|
||||||
|
--
|
Loading…
Reference in a new issue