diff options
author | Travis Watkins <amaranth@ubuntu.com> | 2013-03-13 17:33:27 -0500 |
---|---|---|
committer | Travis Watkins <amaranth@ubuntu.com> | 2013-03-15 13:28:59 -0500 |
commit | 83d29e461c85733f0113b6eb19db6e3b42da2949 (patch) | |
tree | b3063a1c28f478ab368d5ba3413a842def68c28f /src/main/java/net/minecraft/server/BlockButtonAbstract.java | |
parent | ba6e4c38cfa98ad291974195cc46d70a4f138ac1 (diff) | |
download | craftbukkit-83d29e461c85733f0113b6eb19db6e3b42da2949.tar craftbukkit-83d29e461c85733f0113b6eb19db6e3b42da2949.tar.gz craftbukkit-83d29e461c85733f0113b6eb19db6e3b42da2949.tar.lz craftbukkit-83d29e461c85733f0113b6eb19db6e3b42da2949.tar.xz craftbukkit-83d29e461c85733f0113b6eb19db6e3b42da2949.zip |
Update CraftBukkit to Minecraft 1.5
Diffstat (limited to 'src/main/java/net/minecraft/server/BlockButtonAbstract.java')
-rw-r--r-- | src/main/java/net/minecraft/server/BlockButtonAbstract.java | 298 |
1 files changed, 298 insertions, 0 deletions
diff --git a/src/main/java/net/minecraft/server/BlockButtonAbstract.java b/src/main/java/net/minecraft/server/BlockButtonAbstract.java new file mode 100644 index 00000000..b8f62e5b --- /dev/null +++ b/src/main/java/net/minecraft/server/BlockButtonAbstract.java @@ -0,0 +1,298 @@ +package net.minecraft.server; + +import java.util.List; +import java.util.Random; + +// CraftBukkit start +import org.bukkit.event.block.BlockRedstoneEvent; +import org.bukkit.event.entity.EntityInteractEvent; +// CraftBukkit end + +public abstract class BlockButtonAbstract extends Block { + + private final boolean a; + + protected BlockButtonAbstract(int i, boolean flag) { + super(i, Material.ORIENTABLE); + this.b(true); + this.a(CreativeModeTab.d); + this.a = flag; + } + + public AxisAlignedBB b(World world, int i, int j, int k) { + return null; + } + + public int a(World world) { + return this.a ? 30 : 20; + } + + public boolean c() { + return false; + } + + public boolean b() { + return false; + } + + public boolean canPlace(World world, int i, int j, int k, int l) { + return l == 2 && world.u(i, j, k + 1) ? true : (l == 3 && world.u(i, j, k - 1) ? true : (l == 4 && world.u(i + 1, j, k) ? true : l == 5 && world.u(i - 1, j, k))); + } + + public boolean canPlace(World world, int i, int j, int k) { + return world.u(i - 1, j, k) ? true : (world.u(i + 1, j, k) ? true : (world.u(i, j, k - 1) ? true : world.u(i, j, k + 1))); + } + + public int getPlacedData(World world, int i, int j, int k, int l, float f, float f1, float f2, int i1) { + int j1 = world.getData(i, j, k); + int k1 = j1 & 8; + + j1 &= 7; + if (l == 2 && world.u(i, j, k + 1)) { + j1 = 4; + } else if (l == 3 && world.u(i, j, k - 1)) { + j1 = 3; + } else if (l == 4 && world.u(i + 1, j, k)) { + j1 = 2; + } else if (l == 5 && world.u(i - 1, j, k)) { + j1 = 1; + } else { + j1 = this.k(world, i, j, k); + } + + return j1 + k1; + } + + private int k(World world, int i, int j, int k) { + return world.u(i - 1, j, k) ? 1 : (world.u(i + 1, j, k) ? 2 : (world.u(i, j, k - 1) ? 3 : (world.u(i, j, k + 1) ? 4 : 1))); + } + + public void doPhysics(World world, int i, int j, int k, int l) { + if (this.m(world, i, j, k)) { + int i1 = world.getData(i, j, k) & 7; + boolean flag = false; + + if (!world.u(i - 1, j, k) && i1 == 1) { + flag = true; + } + + if (!world.u(i + 1, j, k) && i1 == 2) { + flag = true; + } + + if (!world.u(i, j, k - 1) && i1 == 3) { + flag = true; + } + + if (!world.u(i, j, k + 1) && i1 == 4) { + flag = true; + } + + if (flag) { + this.c(world, i, j, k, world.getData(i, j, k), 0); + world.setAir(i, j, k); + } + } + } + + private boolean m(World world, int i, int j, int k) { + if (!this.canPlace(world, i, j, k)) { + this.c(world, i, j, k, world.getData(i, j, k), 0); + world.setAir(i, j, k); + return false; + } else { + return true; + } + } + + public void updateShape(IBlockAccess iblockaccess, int i, int j, int k) { + int l = iblockaccess.getData(i, j, k); + + this.d(l); + } + + private void d(int i) { + int j = i & 7; + boolean flag = (i & 8) > 0; + float f = 0.375F; + float f1 = 0.625F; + float f2 = 0.1875F; + float f3 = 0.125F; + + if (flag) { + f3 = 0.0625F; + } + + if (j == 1) { + this.a(0.0F, f, 0.5F - f2, f3, f1, 0.5F + f2); + } else if (j == 2) { + this.a(1.0F - f3, f, 0.5F - f2, 1.0F, f1, 0.5F + f2); + } else if (j == 3) { + this.a(0.5F - f2, f, 0.0F, 0.5F + f2, f1, f3); + } else if (j == 4) { + this.a(0.5F - f2, f, 1.0F - f3, 0.5F + f2, f1, 1.0F); + } + } + + public void attack(World world, int i, int j, int k, EntityHuman entityhuman) {} + + public boolean interact(World world, int i, int j, int k, EntityHuman entityhuman, int l, float f, float f1, float f2) { + int i1 = world.getData(i, j, k); + int j1 = i1 & 7; + int k1 = 8 - (i1 & 8); + + if (k1 == 0) { + return true; + } else { + // CraftBukkit start + org.bukkit.block.Block block = world.getWorld().getBlockAt(i, j, k); + int old = (k1 != 8) ? 15 : 0; + int current = (k1 == 8) ? 15 : 0; + + BlockRedstoneEvent eventRedstone = new BlockRedstoneEvent(block, old, current); + world.getServer().getPluginManager().callEvent(eventRedstone); + + if ((eventRedstone.getNewCurrent() > 0) != (k1 == 8)) { + return true; + } + // CraftBukkit end + + world.setData(i, j, k, j1 + k1, 3); + world.g(i, j, k, i, j, k); + world.makeSound((double) i + 0.5D, (double) j + 0.5D, (double) k + 0.5D, "random.click", 0.3F, 0.6F); + this.d(world, i, j, k, j1); + world.a(i, j, k, this.id, this.a(world)); + return true; + } + } + + public void remove(World world, int i, int j, int k, int l, int i1) { + if ((i1 & 8) > 0) { + int j1 = i1 & 7; + + this.d(world, i, j, k, j1); + } + + super.remove(world, i, j, k, l, i1); + } + + public int b(IBlockAccess iblockaccess, int i, int j, int k, int l) { + return (iblockaccess.getData(i, j, k) & 8) > 0 ? 15 : 0; + } + + public int c(IBlockAccess iblockaccess, int i, int j, int k, int l) { + int i1 = iblockaccess.getData(i, j, k); + + if ((i1 & 8) == 0) { + return 0; + } else { + int j1 = i1 & 7; + + return j1 == 5 && l == 1 ? 15 : (j1 == 4 && l == 2 ? 15 : (j1 == 3 && l == 3 ? 15 : (j1 == 2 && l == 4 ? 15 : (j1 == 1 && l == 5 ? 15 : 0)))); + } + } + + public boolean isPowerSource() { + return true; + } + + public void a(World world, int i, int j, int k, Random random) { + if (!world.isStatic) { + int l = world.getData(i, j, k); + + if ((l & 8) != 0) { + // CraftBukkit start + org.bukkit.block.Block block = world.getWorld().getBlockAt(i, j, k); + + BlockRedstoneEvent eventRedstone = new BlockRedstoneEvent(block, 15, 0); + world.getServer().getPluginManager().callEvent(eventRedstone); + + if (eventRedstone.getNewCurrent() > 0) { + return; + } + // CraftBukkit end + + if (this.a) { + this.n(world, i, j, k); + } else { + world.setData(i, j, k, l & 7, 3); + int i1 = l & 7; + + this.d(world, i, j, k, i1); + world.makeSound((double) i + 0.5D, (double) j + 0.5D, (double) k + 0.5D, "random.click", 0.3F, 0.5F); + world.g(i, j, k, i, j, k); + } + } + } + } + + public void g() { + float f = 0.1875F; + float f1 = 0.125F; + float f2 = 0.125F; + + this.a(0.5F - f, 0.5F - f1, 0.5F - f2, 0.5F + f, 0.5F + f1, 0.5F + f2); + } + + public void a(World world, int i, int j, int k, Entity entity) { + if (!world.isStatic) { + if (this.a) { + if ((world.getData(i, j, k) & 8) == 0) { + // CraftBukkit start - Call interaction when entities (currently arrows) hit wooden buttons + EntityInteractEvent event = new EntityInteractEvent(entity.getBukkitEntity(), world.getWorld().getBlockAt(i, j, k)); + world.getServer().getPluginManager().callEvent(event); + + if (event.isCancelled()) { + return; + } + // CraftBukkit end + + this.n(world, i, j, k); + } + } + } + } + + private void n(World world, int i, int j, int k) { + int l = world.getData(i, j, k); + int i1 = l & 7; + boolean flag = (l & 8) != 0; + + this.d(l); + List list = world.a(EntityArrow.class, AxisAlignedBB.a().a((double) i + this.minX, (double) j + this.minY, (double) k + this.minZ, (double) i + this.maxX, (double) j + this.maxY, (double) k + this.maxZ)); + boolean flag1 = !list.isEmpty(); + + if (flag1 && !flag) { + world.setData(i, j, k, i1 | 8, 3); + this.d(world, i, j, k, i1); + world.g(i, j, k, i, j, k); + world.makeSound((double) i + 0.5D, (double) j + 0.5D, (double) k + 0.5D, "random.click", 0.3F, 0.6F); + } + + if (!flag1 && flag) { + world.setData(i, j, k, i1, 3); + this.d(world, i, j, k, i1); + world.g(i, j, k, i, j, k); + world.makeSound((double) i + 0.5D, (double) j + 0.5D, (double) k + 0.5D, "random.click", 0.3F, 0.5F); + } + + if (flag1) { + world.a(i, j, k, this.id, this.a(world)); + } + } + + private void d(World world, int i, int j, int k, int l) { + world.applyPhysics(i, j, k, this.id); + if (l == 1) { + world.applyPhysics(i - 1, j, k, this.id); + } else if (l == 2) { + world.applyPhysics(i + 1, j, k, this.id); + } else if (l == 3) { + world.applyPhysics(i, j, k - 1, this.id); + } else if (l == 4) { + world.applyPhysics(i, j, k + 1, this.id); + } else { + world.applyPhysics(i, j - 1, k, this.id); + } + } +} |