summaryrefslogtreecommitdiffstats
path: root/src/main/java
diff options
context:
space:
mode:
authorfeildmaster <admin@feildmaster.com>2012-12-27 20:45:21 -0600
committerfeildmaster <admin@feildmaster.com>2012-12-27 20:45:21 -0600
commit54b2707ba7ef53f7d7523387d3aeab296152d628 (patch)
treef191b64b3d4db33993be61898dcf066d5590bef5 /src/main/java
parent25732f0487570d17615c42560d36e85b9100518e (diff)
downloadcraftbukkit-54b2707ba7ef53f7d7523387d3aeab296152d628.tar
craftbukkit-54b2707ba7ef53f7d7523387d3aeab296152d628.tar.gz
craftbukkit-54b2707ba7ef53f7d7523387d3aeab296152d628.tar.lz
craftbukkit-54b2707ba7ef53f7d7523387d3aeab296152d628.tar.xz
craftbukkit-54b2707ba7ef53f7d7523387d3aeab296152d628.zip
Fix discrepancies in NBT and ItemMeta. Fixes BUKKIT-3279
An ItemStack gains the tag name "tag" when the stack is serialized to NBT, however items don't have a tag *until* they are serialized at least once. So to solve this, we remove the tag name when loading the NBT data. Another problem with NBT are TagLists, when transferring tag lists between the server and the client the names are lost, and so we simply don't add a name to the tag.
Diffstat (limited to 'src/main/java')
-rw-r--r--src/main/java/net/minecraft/server/ItemStack.java3
-rw-r--r--src/main/java/org/bukkit/craftbukkit/inventory/CraftMetaBook.java6
-rw-r--r--src/main/java/org/bukkit/craftbukkit/inventory/CraftMetaItem.java19
3 files changed, 17 insertions, 11 deletions
diff --git a/src/main/java/net/minecraft/server/ItemStack.java b/src/main/java/net/minecraft/server/ItemStack.java
index a09d8d89..453ca4ac 100644
--- a/src/main/java/net/minecraft/server/ItemStack.java
+++ b/src/main/java/net/minecraft/server/ItemStack.java
@@ -106,7 +106,8 @@ public final class ItemStack {
this.count = nbttagcompound.getByte("Count");
this.damage = nbttagcompound.getShort("Damage");
if (nbttagcompound.hasKey("tag")) {
- this.tag = nbttagcompound.getCompound("tag");
+ // CraftBukkit - clear name from compound
+ this.tag = (NBTTagCompound) nbttagcompound.getCompound("tag").setName("");
}
}
diff --git a/src/main/java/org/bukkit/craftbukkit/inventory/CraftMetaBook.java b/src/main/java/org/bukkit/craftbukkit/inventory/CraftMetaBook.java
index b49974b5..476089a1 100644
--- a/src/main/java/org/bukkit/craftbukkit/inventory/CraftMetaBook.java
+++ b/src/main/java/org/bukkit/craftbukkit/inventory/CraftMetaBook.java
@@ -91,11 +91,7 @@ class CraftMetaBook extends CraftMetaItem implements BookMeta {
}
if (hasPages()) {
- NBTTagList itemPages = new NBTTagList(BOOK_PAGES.NBT);
- for (int i = 1; i < pages.size() + 1; i++) {
- itemPages.add(new NBTTagString(String.valueOf(i), pages.get(i - 1)));
- }
- itemData.set(BOOK_PAGES.NBT, itemPages);
+ itemData.set(BOOK_PAGES.NBT, createStringList(pages, BOOK_PAGES));
}
}
diff --git a/src/main/java/org/bukkit/craftbukkit/inventory/CraftMetaItem.java b/src/main/java/org/bukkit/craftbukkit/inventory/CraftMetaItem.java
index f8f9f261..cc976ebf 100644
--- a/src/main/java/org/bukkit/craftbukkit/inventory/CraftMetaItem.java
+++ b/src/main/java/org/bukkit/craftbukkit/inventory/CraftMetaItem.java
@@ -307,11 +307,7 @@ class CraftMetaItem implements ItemMeta, Repairable {
}
if (hasLore()) {
- NBTTagList list = new NBTTagList(LORE.NBT);
- for (int i = 0; i < lore.size(); i++) {
- list.add(new NBTTagString(String.valueOf(i), lore.get(i)));
- }
- setDisplayTag(itemTag, LORE.NBT, list);
+ setDisplayTag(itemTag, LORE.NBT, createStringList(lore, LORE));
}
applyEnchantments(enchantments, itemTag, ENCHANTMENTS);
@@ -321,6 +317,19 @@ class CraftMetaItem implements ItemMeta, Repairable {
}
}
+ static NBTTagList createStringList(List<String> list, ItemMetaKey key) {
+ if (list == null || list.isEmpty()) {
+ return null;
+ }
+
+ NBTTagList tagList = new NBTTagList(key.NBT);
+ for (int i = 0; i < list.size(); i++) {
+ tagList.add(new NBTTagString("", list.get(i)));
+ }
+
+ return tagList;
+ }
+
static void applyEnchantments(Map<Enchantment, Integer> enchantments, NBTTagCompound tag, ItemMetaKey key) {
if (enchantments == null || enchantments.size() == 0) {
return;