diff options
Diffstat (limited to 'src/main/java/net/minecraft/server/BlockLever.java')
-rw-r--r-- | src/main/java/net/minecraft/server/BlockLever.java | 103 |
1 files changed, 60 insertions, 43 deletions
diff --git a/src/main/java/net/minecraft/server/BlockLever.java b/src/main/java/net/minecraft/server/BlockLever.java index 11489b14..a225d283 100644 --- a/src/main/java/net/minecraft/server/BlockLever.java +++ b/src/main/java/net/minecraft/server/BlockLever.java @@ -4,12 +4,12 @@ import org.bukkit.event.block.BlockRedstoneEvent; // CraftBukkit public class BlockLever extends Block { - protected BlockLever(int i, int j) { - super(i, j, Material.ORIENTABLE); + protected BlockLever(int i) { + super(i, Material.ORIENTABLE); this.a(CreativeModeTab.d); } - public AxisAlignedBB e(World world, int i, int j, int k) { + public AxisAlignedBB b(World world, int i, int j, int k) { return null; } @@ -26,46 +26,66 @@ public class BlockLever extends Block { } public boolean canPlace(World world, int i, int j, int k, int l) { - return l == 0 && world.t(i, j + 1, k) ? true : (l == 1 && world.v(i, j - 1, k) ? true : (l == 2 && world.t(i, j, k + 1) ? true : (l == 3 && world.t(i, j, k - 1) ? true : (l == 4 && world.t(i + 1, j, k) ? true : l == 5 && world.t(i - 1, j, k))))); + return l == 0 && world.u(i, j + 1, k) ? true : (l == 1 && world.w(i, j - 1, k) ? true : (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.t(i - 1, j, k) ? true : (world.t(i + 1, j, k) ? true : (world.t(i, j, k - 1) ? true : (world.t(i, j, k + 1) ? true : (world.v(i, j - 1, k) ? true : world.t(i, j + 1, 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) ? true : (world.w(i, j - 1, k) ? true : world.u(i, j + 1, k))))); } public int getPlacedData(World world, int i, int j, int k, int l, float f, float f1, float f2, int i1) { int j1 = i1 & 8; int k1 = i1 & 7; + byte b0 = -1; - k1 = -1; - if (l == 0 && world.t(i, j + 1, k)) { - k1 = world.random.nextBoolean() ? 0 : 7; + if (l == 0 && world.u(i, j + 1, k)) { + b0 = 0; } - if (l == 1 && world.v(i, j - 1, k)) { - k1 = 5 + world.random.nextInt(2); + if (l == 1 && world.w(i, j - 1, k)) { + b0 = 5; } - if (l == 2 && world.t(i, j, k + 1)) { - k1 = 4; + if (l == 2 && world.u(i, j, k + 1)) { + b0 = 4; } - if (l == 3 && world.t(i, j, k - 1)) { - k1 = 3; + if (l == 3 && world.u(i, j, k - 1)) { + b0 = 3; } - if (l == 4 && world.t(i + 1, j, k)) { - k1 = 2; + if (l == 4 && world.u(i + 1, j, k)) { + b0 = 2; } - if (l == 5 && world.t(i - 1, j, k)) { - k1 = 1; + if (l == 5 && world.u(i - 1, j, k)) { + b0 = 1; } - return k1 + j1; + return b0 + j1; } - public static int e(int i) { + public void postPlace(World world, int i, int j, int k, EntityLiving entityliving, ItemStack itemstack) { + int l = world.getData(i, j, k); + int i1 = l & 7; + int j1 = l & 8; + + if (i1 == d(1)) { + if ((MathHelper.floor((double) (entityliving.yaw * 4.0F / 360.0F) + 0.5D) & 1) == 0) { + world.setData(i, j, k, 5 | j1, 2); + } else { + world.setData(i, j, k, 6 | j1, 2); + } + } else if (i1 == d(0)) { + if ((MathHelper.floor((double) (entityliving.yaw * 4.0F / 360.0F) + 0.5D) & 1) == 0) { + world.setData(i, j, k, 7 | j1, 2); + } else { + world.setData(i, j, k, 0 | j1, 2); + } + } + } + + public static int d(int i) { switch (i) { case 0: return 0; @@ -91,53 +111,53 @@ public class BlockLever extends Block { } public void doPhysics(World world, int i, int j, int k, int l) { - if (this.l(world, i, j, k)) { + if (this.k(world, i, j, k)) { int i1 = world.getData(i, j, k) & 7; boolean flag = false; - if (!world.t(i - 1, j, k) && i1 == 1) { + if (!world.u(i - 1, j, k) && i1 == 1) { flag = true; } - if (!world.t(i + 1, j, k) && i1 == 2) { + if (!world.u(i + 1, j, k) && i1 == 2) { flag = true; } - if (!world.t(i, j, k - 1) && i1 == 3) { + if (!world.u(i, j, k - 1) && i1 == 3) { flag = true; } - if (!world.t(i, j, k + 1) && i1 == 4) { + if (!world.u(i, j, k + 1) && i1 == 4) { flag = true; } - if (!world.v(i, j - 1, k) && i1 == 5) { + if (!world.w(i, j - 1, k) && i1 == 5) { flag = true; } - if (!world.v(i, j - 1, k) && i1 == 6) { + if (!world.w(i, j - 1, k) && i1 == 6) { flag = true; } - if (!world.t(i, j + 1, k) && i1 == 0) { + if (!world.u(i, j + 1, k) && i1 == 0) { flag = true; } - if (!world.t(i, j + 1, k) && i1 == 7) { + if (!world.u(i, j + 1, k) && i1 == 7) { flag = true; } if (flag) { this.c(world, i, j, k, world.getData(i, j, k), 0); - world.setTypeId(i, j, k, 0); + world.setAir(i, j, k); } } } - private boolean l(World world, int i, int j, int k) { + private boolean k(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.setTypeId(i, j, k, 0); + world.setAir(i, j, k); return false; } else { return true; @@ -167,8 +187,6 @@ public class BlockLever extends Block { } } - 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) { if (world.isStatic) { return true; @@ -179,8 +197,8 @@ public class BlockLever extends Block { // CraftBukkit start - Interact Lever org.bukkit.block.Block block = world.getWorld().getBlockAt(i, j, k); - int old = (k1 != 8) ? 1 : 0; - int current = (k1 == 8) ? 1 : 0; + int old = (k1 != 8) ? 15 : 0; + int current = (k1 == 8) ? 15 : 0; BlockRedstoneEvent eventRedstone = new BlockRedstoneEvent(block, old, current); world.getServer().getPluginManager().callEvent(eventRedstone); @@ -190,8 +208,7 @@ public class BlockLever extends Block { } // CraftBukkit end - world.setData(i, j, k, j1 + k1); - world.e(i, j, k, i, j, k); + world.setData(i, j, k, j1 + k1, 3); world.makeSound((double) i + 0.5D, (double) j + 0.5D, (double) k + 0.5D, "random.click", 0.3F, k1 > 0 ? 0.6F : 0.5F); world.applyPhysics(i, j, k, this.id); if (j1 == 1) { @@ -239,19 +256,19 @@ public class BlockLever extends Block { super.remove(world, i, j, k, l, i1); } - public boolean b(IBlockAccess iblockaccess, int i, int j, int k, int l) { - return (iblockaccess.getData(i, j, k) & 8) > 0; + public int b(IBlockAccess iblockaccess, int i, int j, int k, int l) { + return (iblockaccess.getData(i, j, k) & 8) > 0 ? 15 : 0; } - public boolean c(IBlockAccess iblockaccess, int i, int j, int k, int l) { + 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 false; + return 0; } else { int j1 = i1 & 7; - return j1 == 0 && l == 0 ? true : (j1 == 7 && l == 0 ? true : (j1 == 6 && l == 1 ? true : (j1 == 5 && l == 1 ? true : (j1 == 4 && l == 2 ? true : (j1 == 3 && l == 3 ? true : (j1 == 2 && l == 4 ? true : j1 == 1 && l == 5)))))); + return j1 == 0 && l == 0 ? 15 : (j1 == 7 && l == 0 ? 15 : (j1 == 6 && l == 1 ? 15 : (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))))))); } } |