From eabf3db61414426366b0ce4f624fa77ff5f4101f Mon Sep 17 00:00:00 2001 From: CraftBukkit/Spigot Date: Mon, 18 Mar 2013 00:32:11 -0600 Subject: [PATCH] BlockState for Command Blocks. Adds BUKKIT-3805. By: Nate Mortensen --- .../bukkit/craftbukkit/block/CraftBlock.java | 2 + .../craftbukkit/block/CraftCommandBlock.java | 48 +++++++++++++++++++ 2 files changed, 50 insertions(+) create mode 100644 paper-server/src/main/java/org/bukkit/craftbukkit/block/CraftCommandBlock.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 90dae627d7..ecd08eb6f8 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 @@ -261,6 +261,8 @@ public class CraftBlock implements Block { return new CraftBrewingStand(this); case SKULL: return new CraftSkull(this); + case COMMAND: + return new CraftCommandBlock(this); default: return new CraftBlockState(this); } diff --git a/paper-server/src/main/java/org/bukkit/craftbukkit/block/CraftCommandBlock.java b/paper-server/src/main/java/org/bukkit/craftbukkit/block/CraftCommandBlock.java new file mode 100644 index 0000000000..4572438d69 --- /dev/null +++ b/paper-server/src/main/java/org/bukkit/craftbukkit/block/CraftCommandBlock.java @@ -0,0 +1,48 @@ +package org.bukkit.craftbukkit.block; + +import net.minecraft.server.TileEntityCommand; +import org.bukkit.block.Block; +import org.bukkit.block.CommandBlock; +import org.bukkit.craftbukkit.CraftWorld; + +public class CraftCommandBlock extends CraftBlockState implements CommandBlock { + private final TileEntityCommand commandBlock; + private String command; + private String name; + + public CraftCommandBlock(Block block) { + super(block); + + CraftWorld world = (CraftWorld) block.getWorld(); + commandBlock = (TileEntityCommand) world.getTileEntityAt(getX(), getY(), getZ()); + command = commandBlock.b; + name = commandBlock.getName(); + } + + public String getCommand() { + return command; + } + + public void setCommand(String command) { + this.command = command != null ? command : ""; + } + + public String getName() { + return name; + } + + public void setName(String name) { + this.name = name != null ? name : "@"; + } + + public boolean update(boolean forced) { + boolean result = super.update(forced); + + if (result) { + commandBlock.b(command); + commandBlock.c(name); + } + + return result; + } +}