From 7e256ae56a1c49155b8327fd3404e5b2cbcb00fa Mon Sep 17 00:00:00 2001 From: Bukkit/Spigot Date: Tue, 24 Mar 2015 15:36:33 +0000 Subject: [PATCH] Add BlockStateMeta which allows creating and editting 1.8's blockEntityTag By: Thinkofdeath --- .../java/org/bukkit/block/BlockState.java | 11 ++++++ .../bukkit/inventory/meta/BlockStateMeta.java | 35 +++++++++++++++++++ 2 files changed, 46 insertions(+) create mode 100644 paper-api/src/main/java/org/bukkit/inventory/meta/BlockStateMeta.java diff --git a/paper-api/src/main/java/org/bukkit/block/BlockState.java b/paper-api/src/main/java/org/bukkit/block/BlockState.java index 96bf1d0d2d..866a73d9eb 100644 --- a/paper-api/src/main/java/org/bukkit/block/BlockState.java +++ b/paper-api/src/main/java/org/bukkit/block/BlockState.java @@ -192,4 +192,15 @@ public interface BlockState extends Metadatable { */ @Deprecated public void setRawData(byte data); + + /** + * Returns whether this state is placed in the world. + * + * Some methods will not work if the blockState isn't + * placed in the world. + * + * @return whether the state is placed in the world + * or 'virtual' (e.g. on an itemstack) + */ + boolean isPlaced(); } diff --git a/paper-api/src/main/java/org/bukkit/inventory/meta/BlockStateMeta.java b/paper-api/src/main/java/org/bukkit/inventory/meta/BlockStateMeta.java new file mode 100644 index 0000000000..4c2a746729 --- /dev/null +++ b/paper-api/src/main/java/org/bukkit/inventory/meta/BlockStateMeta.java @@ -0,0 +1,35 @@ + +package org.bukkit.inventory.meta; + +import org.bukkit.block.BlockState; + +public interface BlockStateMeta extends ItemMeta { + + /** + * Returns whether the item has a block state currently + * attached to it. + * + * @return whether a block state is already attached + */ + boolean hasBlockState(); + + /** + * Returns the currently attached block state for this + * item or creates a new one if one doesn't exist. + * + * The state is a copy, it must be set back (or to another + * item) with {@link #setBlockState(org.bukkit.block.BlockState)} + * + * @return the attached state or a new state + */ + BlockState getBlockState(); + + /** + * Attaches a copy of the passed block state to the item. + * + * @param blockState the block state to attach to the block. + * @throws IllegalArgumentException if the blockState is null + * or invalid for this item. + */ + void setBlockState(BlockState blockState); +}