From 40acfc98f2c00f7c270c2eec135557c6da1e0ca1 Mon Sep 17 00:00:00 2001 From: CraftBukkit/Spigot Date: Sun, 18 Sep 2016 09:58:54 +1000 Subject: [PATCH] SPIGOT-2679: Add meta for StructureBlock By: md_5 --- .../bukkit/craftbukkit/block/CraftBlock.java | 2 ++ .../block/CraftStructureBlock.java | 23 +++++++++++++++++++ .../inventory/CraftItemFactory.java | 1 + .../craftbukkit/inventory/CraftItemStack.java | 1 + .../inventory/CraftMetaBlockState.java | 20 ++++++++++++---- 5 files changed, 42 insertions(+), 5 deletions(-) create mode 100644 paper-server/src/main/java/org/bukkit/craftbukkit/block/CraftStructureBlock.java diff --git a/paper-server/src/main/java/org/bukkit/craftbukkit/block/CraftBlock.java b/paper-server/src/main/java/org/bukkit/craftbukkit/block/CraftBlock.java index 03addbd609..89b23e298e 100644 --- a/paper-server/src/main/java/org/bukkit/craftbukkit/block/CraftBlock.java +++ b/paper-server/src/main/java/org/bukkit/craftbukkit/block/CraftBlock.java @@ -304,6 +304,8 @@ public class CraftBlock implements Block { return new CraftBanner(this); case FLOWER_POT: return new CraftFlowerPot(this); + case STRUCTURE_BLOCK: + return new CraftStructureBlock(this); default: return new CraftBlockState(this); } diff --git a/paper-server/src/main/java/org/bukkit/craftbukkit/block/CraftStructureBlock.java b/paper-server/src/main/java/org/bukkit/craftbukkit/block/CraftStructureBlock.java new file mode 100644 index 0000000000..038aa21d42 --- /dev/null +++ b/paper-server/src/main/java/org/bukkit/craftbukkit/block/CraftStructureBlock.java @@ -0,0 +1,23 @@ +package org.bukkit.craftbukkit.block; + +import net.minecraft.server.TileEntityStructure; +import org.bukkit.Material; +import org.bukkit.block.Block; +import org.bukkit.craftbukkit.CraftWorld; + +public class CraftStructureBlock extends CraftBlockState { + + private final TileEntityStructure structure; + + public CraftStructureBlock(Block block) { + super(block); + + this.structure = (TileEntityStructure) ((CraftWorld) block.getWorld()).getTileEntityAt(getX(), getY(), getZ()); + } + + public CraftStructureBlock(Material material, TileEntityStructure structure) { + super(material); + + this.structure = structure; + } +} diff --git a/paper-server/src/main/java/org/bukkit/craftbukkit/inventory/CraftItemFactory.java b/paper-server/src/main/java/org/bukkit/craftbukkit/inventory/CraftItemFactory.java index 2e6c566993..4e4a46f14b 100644 --- a/paper-server/src/main/java/org/bukkit/craftbukkit/inventory/CraftItemFactory.java +++ b/paper-server/src/main/java/org/bukkit/craftbukkit/inventory/CraftItemFactory.java @@ -113,6 +113,7 @@ public final class CraftItemFactory implements ItemFactory { case REDSTONE_COMPARATOR: case FLOWER_POT_ITEM: case SHIELD: + case STRUCTURE_BLOCK: return new CraftMetaBlockState(meta, material); default: return new CraftMetaItem(meta); diff --git a/paper-server/src/main/java/org/bukkit/craftbukkit/inventory/CraftItemStack.java b/paper-server/src/main/java/org/bukkit/craftbukkit/inventory/CraftItemStack.java index 8b6fd4ff50..6f5dcbd652 100644 --- a/paper-server/src/main/java/org/bukkit/craftbukkit/inventory/CraftItemStack.java +++ b/paper-server/src/main/java/org/bukkit/craftbukkit/inventory/CraftItemStack.java @@ -374,6 +374,7 @@ public final class CraftItemStack extends ItemStack { case REDSTONE_COMPARATOR: case FLOWER_POT_ITEM: case SHIELD: + case STRUCTURE_BLOCK: return new CraftMetaBlockState(item.getTag(), CraftMagicNumbers.getMaterial(item.getItem())); default: return new CraftMetaItem(item.getTag()); diff --git a/paper-server/src/main/java/org/bukkit/craftbukkit/inventory/CraftMetaBlockState.java b/paper-server/src/main/java/org/bukkit/craftbukkit/inventory/CraftMetaBlockState.java index ee36785e9e..b9d4717f56 100644 --- a/paper-server/src/main/java/org/bukkit/craftbukkit/inventory/CraftMetaBlockState.java +++ b/paper-server/src/main/java/org/bukkit/craftbukkit/inventory/CraftMetaBlockState.java @@ -4,7 +4,6 @@ import com.google.common.base.Objects; import com.google.common.collect.ImmutableMap; import java.util.Map; import net.minecraft.server.BlockJukeBox; -import net.minecraft.server.MinecraftServer; import net.minecraft.server.NBTBase; import net.minecraft.server.NBTTagCompound; import net.minecraft.server.TileEntity; @@ -23,6 +22,7 @@ import net.minecraft.server.TileEntityMobSpawner; import net.minecraft.server.TileEntityNote; import net.minecraft.server.TileEntitySign; import net.minecraft.server.TileEntitySkull; +import net.minecraft.server.TileEntityStructure; import org.apache.commons.lang.Validate; import org.bukkit.Material; import org.bukkit.block.BlockState; @@ -44,14 +44,15 @@ import org.bukkit.craftbukkit.block.CraftJukebox; import org.bukkit.craftbukkit.block.CraftNoteBlock; import org.bukkit.craftbukkit.block.CraftSign; import org.bukkit.craftbukkit.block.CraftSkull; +import org.bukkit.craftbukkit.block.CraftStructureBlock; import org.bukkit.inventory.meta.BlockStateMeta; @DelegateDeserialization(CraftMetaItem.SerializableMeta.class) public class CraftMetaBlockState extends CraftMetaItem implements BlockStateMeta { - + @ItemMetaKey.Specific(ItemMetaKey.Specific.To.NBT) static final ItemMetaKey BLOCK_ENTITY_TAG = new ItemMetaKey("BlockEntityTag"); - + final Material material; NBTTagCompound blockEntityTag; @@ -72,7 +73,7 @@ public class CraftMetaBlockState extends CraftMetaItem implements BlockStateMeta CraftMetaBlockState(NBTTagCompound tag, Material material) { super(tag); this.material = material; - + if (tag.hasKeyOfType(BLOCK_ENTITY_TAG.NBT, 10)) { blockEntityTag = tag.getCompound(BLOCK_ENTITY_TAG.NBT); } else { @@ -94,7 +95,7 @@ public class CraftMetaBlockState extends CraftMetaItem implements BlockStateMeta @Override void applyToItem(NBTTagCompound tag) { super.applyToItem(tag); - + if (blockEntityTag != null) { tag.set(BLOCK_ENTITY_TAG.NBT, blockEntityTag); } @@ -179,6 +180,7 @@ public class CraftMetaBlockState extends CraftMetaItem implements BlockStateMeta case REDSTONE_COMPARATOR: case FLOWER_POT_ITEM: case SHIELD: + case STRUCTURE_BLOCK: return true; } return false; @@ -286,6 +288,11 @@ public class CraftMetaBlockState extends CraftMetaItem implements BlockStateMeta te = new TileEntityFlowerPot(); } return new CraftFlowerPot(material, (TileEntityFlowerPot) te); + case STRUCTURE_BLOCK: + if (te == null) { + te = new TileEntityStructure(); + } + return new CraftStructureBlock(material, (TileEntityStructure) te); default: throw new IllegalStateException("Missing blockState for " + material); } @@ -356,6 +363,9 @@ public class CraftMetaBlockState extends CraftMetaItem implements BlockStateMeta case FLOWER_POT_ITEM: valid = te instanceof TileEntityFlowerPot; break; + case STRUCTURE_BLOCK: + valid = te instanceof TileEntityStructure; + break; default: valid = false; break;