diff options
author | Thinkofdeath <thinkofdeath@spigotmc.org> | 2014-11-26 08:32:16 +1100 |
---|---|---|
committer | md_5 <git@md-5.net> | 2014-11-28 17:16:30 +1100 |
commit | 24557bc2b37deb6a0edf497d547471832457b1dd (patch) | |
tree | c560572889a3b0b34964a0cddb35dc87fda3c914 /src/main/java/net/minecraft/server/BlockRedstoneTorch.java | |
parent | a4805dbd77da057cc1ea0bf344379bc6e53ca1f6 (diff) | |
download | craftbukkit-24557bc2b37deb6a0edf497d547471832457b1dd.tar craftbukkit-24557bc2b37deb6a0edf497d547471832457b1dd.tar.gz craftbukkit-24557bc2b37deb6a0edf497d547471832457b1dd.tar.lz craftbukkit-24557bc2b37deb6a0edf497d547471832457b1dd.tar.xz craftbukkit-24557bc2b37deb6a0edf497d547471832457b1dd.zip |
Update to Minecraft 1.8
For more information please see http://www.spigotmc.org/
Diffstat (limited to 'src/main/java/net/minecraft/server/BlockRedstoneTorch.java')
-rw-r--r-- | src/main/java/net/minecraft/server/BlockRedstoneTorch.java | 176 |
1 files changed, 0 insertions, 176 deletions
diff --git a/src/main/java/net/minecraft/server/BlockRedstoneTorch.java b/src/main/java/net/minecraft/server/BlockRedstoneTorch.java deleted file mode 100644 index 8e014149..00000000 --- a/src/main/java/net/minecraft/server/BlockRedstoneTorch.java +++ /dev/null @@ -1,176 +0,0 @@ -package net.minecraft.server; - -import java.util.ArrayList; -import java.util.HashMap; -import java.util.List; -import java.util.Map; -import java.util.Random; - -import org.bukkit.event.block.BlockRedstoneEvent; // CraftBukkit - -public class BlockRedstoneTorch extends BlockTorch { - - private boolean isOn; - private static Map b = new HashMap(); - - private boolean a(World world, int i, int j, int k, boolean flag) { - if (!b.containsKey(world)) { - b.put(world, new ArrayList()); - } - - List list = (List) b.get(world); - - if (flag) { - list.add(new RedstoneUpdateInfo(i, j, k, world.getTime())); - } - - int l = 0; - - for (int i1 = 0; i1 < list.size(); ++i1) { - RedstoneUpdateInfo redstoneupdateinfo = (RedstoneUpdateInfo) list.get(i1); - - if (redstoneupdateinfo.a == i && redstoneupdateinfo.b == j && redstoneupdateinfo.c == k) { - ++l; - if (l >= 8) { - return true; - } - } - } - - return false; - } - - protected BlockRedstoneTorch(boolean flag) { - this.isOn = flag; - this.a(true); - this.a((CreativeModeTab) null); - } - - public int a(World world) { - return 2; - } - - public void onPlace(World world, int i, int j, int k) { - if (world.getData(i, j, k) == 0) { - super.onPlace(world, i, j, k); - } - - if (this.isOn) { - world.applyPhysics(i, j - 1, k, this); - world.applyPhysics(i, j + 1, k, this); - world.applyPhysics(i - 1, j, k, this); - world.applyPhysics(i + 1, j, k, this); - world.applyPhysics(i, j, k - 1, this); - world.applyPhysics(i, j, k + 1, this); - } - } - - public void remove(World world, int i, int j, int k, Block block, int l) { - if (this.isOn) { - world.applyPhysics(i, j - 1, k, this); - world.applyPhysics(i, j + 1, k, this); - world.applyPhysics(i - 1, j, k, this); - world.applyPhysics(i + 1, j, k, this); - world.applyPhysics(i, j, k - 1, this); - world.applyPhysics(i, j, k + 1, this); - } - } - - public int b(IBlockAccess iblockaccess, int i, int j, int k, int l) { - if (!this.isOn) { - return 0; - } else { - int i1 = iblockaccess.getData(i, j, k); - - return i1 == 5 && l == 1 ? 0 : (i1 == 3 && l == 3 ? 0 : (i1 == 4 && l == 2 ? 0 : (i1 == 1 && l == 5 ? 0 : (i1 == 2 && l == 4 ? 0 : 15)))); - } - } - - private boolean m(World world, int i, int j, int k) { - int l = world.getData(i, j, k); - - return l == 5 && world.isBlockFacePowered(i, j - 1, k, 0) ? true : (l == 3 && world.isBlockFacePowered(i, j, k - 1, 2) ? true : (l == 4 && world.isBlockFacePowered(i, j, k + 1, 3) ? true : (l == 1 && world.isBlockFacePowered(i - 1, j, k, 4) ? true : l == 2 && world.isBlockFacePowered(i + 1, j, k, 5)))); - } - - public void a(World world, int i, int j, int k, Random random) { - boolean flag = this.m(world, i, j, k); - List list = (List) b.get(world); - - while (list != null && !list.isEmpty() && world.getTime() - ((RedstoneUpdateInfo) list.get(0)).d > 60L) { - list.remove(0); - } - - // CraftBukkit start - org.bukkit.plugin.PluginManager manager = world.getServer().getPluginManager(); - org.bukkit.block.Block block = world.getWorld().getBlockAt(i, j, k); - int oldCurrent = this.isOn ? 15 : 0; - - BlockRedstoneEvent event = new BlockRedstoneEvent(block, oldCurrent, oldCurrent); - // CraftBukkit end - - if (this.isOn) { - if (flag) { - // CraftBukkit start - if (oldCurrent != 0) { - event.setNewCurrent(0); - manager.callEvent(event); - if (event.getNewCurrent() != 0) { - return; - } - } - // CraftBukkit end - - world.setTypeAndData(i, j, k, Blocks.REDSTONE_TORCH_OFF, world.getData(i, j, k), 3); - if (this.a(world, i, j, k, true)) { - world.makeSound((double) ((float) i + 0.5F), (double) ((float) j + 0.5F), (double) ((float) k + 0.5F), "random.fizz", 0.5F, 2.6F + (world.random.nextFloat() - world.random.nextFloat()) * 0.8F); - - for (int l = 0; l < 5; ++l) { - double d0 = (double) i + random.nextDouble() * 0.6D + 0.2D; - double d1 = (double) j + random.nextDouble() * 0.6D + 0.2D; - double d2 = (double) k + random.nextDouble() * 0.6D + 0.2D; - - world.addParticle("smoke", d0, d1, d2, 0.0D, 0.0D, 0.0D); - } - } - } - } else if (!flag && !this.a(world, i, j, k, false)) { - // CraftBukkit start - if (oldCurrent != 15) { - event.setNewCurrent(15); - manager.callEvent(event); - if (event.getNewCurrent() != 15) { - return; - } - } - // CraftBukkit end - - world.setTypeAndData(i, j, k, Blocks.REDSTONE_TORCH_ON, world.getData(i, j, k), 3); - } - } - - public void doPhysics(World world, int i, int j, int k, Block block) { - if (!this.b(world, i, j, k, block)) { - boolean flag = this.m(world, i, j, k); - - if (this.isOn && flag || !this.isOn && !flag) { - world.a(i, j, k, this, this.a(world)); - } - } - } - - public int c(IBlockAccess iblockaccess, int i, int j, int k, int l) { - return l == 0 ? this.b(iblockaccess, i, j, k, l) : 0; - } - - public Item getDropType(int i, Random random, int j) { - return Item.getItemOf(Blocks.REDSTONE_TORCH_ON); - } - - public boolean isPowerSource() { - return true; - } - - public boolean c(Block block) { - return block == Blocks.REDSTONE_TORCH_OFF || block == Blocks.REDSTONE_TORCH_ON; - } -} |