From ee572114dd5bc0d1c15962300fe4715766731c06 Mon Sep 17 00:00:00 2001 From: Travis Watkins Date: Fri, 29 Mar 2013 22:26:27 -0500 Subject: [PATCH] Add Beacon block state for hopper events. Fixes BUKKIT-3932 --- .../minecraft/server/TileEntityBeacon.java | 2 +- .../bukkit/craftbukkit/block/CraftBeacon.java | 37 +++++++++++++++++++ .../bukkit/craftbukkit/block/CraftBlock.java | 2 + 3 files changed, 40 insertions(+), 1 deletion(-) create mode 100644 src/main/java/org/bukkit/craftbukkit/block/CraftBeacon.java diff --git a/src/main/java/net/minecraft/server/TileEntityBeacon.java b/src/main/java/net/minecraft/server/TileEntityBeacon.java index 693792934d..4ceb57e543 100644 --- a/src/main/java/net/minecraft/server/TileEntityBeacon.java +++ b/src/main/java/net/minecraft/server/TileEntityBeacon.java @@ -22,7 +22,7 @@ public class TileEntityBeacon extends TileEntity implements IInventory { private int maxStack = MAX_STACK; public ItemStack[] getContents() { - return null; + return new ItemStack[] { this.h }; // Should be inventorySlot } public void onOpen(CraftHumanEntity who) { diff --git a/src/main/java/org/bukkit/craftbukkit/block/CraftBeacon.java b/src/main/java/org/bukkit/craftbukkit/block/CraftBeacon.java new file mode 100644 index 0000000000..c39857eca7 --- /dev/null +++ b/src/main/java/org/bukkit/craftbukkit/block/CraftBeacon.java @@ -0,0 +1,37 @@ +package org.bukkit.craftbukkit.block; + +import net.minecraft.server.TileEntityBeacon; + +import org.bukkit.block.Block; +import org.bukkit.block.Beacon; +import org.bukkit.craftbukkit.CraftWorld; +import org.bukkit.craftbukkit.inventory.CraftInventory; +import org.bukkit.inventory.Inventory; + +public class CraftBeacon extends CraftBlockState implements Beacon { + private final CraftWorld world; + private final TileEntityBeacon beacon; + + public CraftBeacon(final Block block) { + super(block); + + world = (CraftWorld) block.getWorld(); + beacon = (TileEntityBeacon) world.getTileEntityAt(getX(), getY(), getZ()); + } + + public Inventory getInventory() { + return new CraftInventory(beacon); + } + + @Override + public boolean update(boolean force) { + boolean result = super.update(force); + + if (result) { + beacon.update(); + } + + return result; + } +} + diff --git a/src/main/java/org/bukkit/craftbukkit/block/CraftBlock.java b/src/main/java/org/bukkit/craftbukkit/block/CraftBlock.java index 2334fb625c..9afe6aef47 100644 --- a/src/main/java/org/bukkit/craftbukkit/block/CraftBlock.java +++ b/src/main/java/org/bukkit/craftbukkit/block/CraftBlock.java @@ -265,6 +265,8 @@ public class CraftBlock implements Block { return new CraftSkull(this); case COMMAND: return new CraftCommandBlock(this); + case BEACON: + return new CraftBeacon(this); default: return new CraftBlockState(this); }