diff options
Diffstat (limited to 'src/main/java/net/minecraft/server/BlockFire.java')
-rw-r--r-- | src/main/java/net/minecraft/server/BlockFire.java | 281 |
1 files changed, 0 insertions, 281 deletions
diff --git a/src/main/java/net/minecraft/server/BlockFire.java b/src/main/java/net/minecraft/server/BlockFire.java deleted file mode 100644 index 44994a14..00000000 --- a/src/main/java/net/minecraft/server/BlockFire.java +++ /dev/null @@ -1,281 +0,0 @@ -package net.minecraft.server; - -import java.util.Random; - -// CraftBukkit start -import org.bukkit.craftbukkit.event.CraftEventFactory; -import org.bukkit.event.block.BlockBurnEvent; -import org.bukkit.event.block.BlockSpreadEvent; -// CraftBukkit end - -public class BlockFire extends Block { - - private int[] a = new int[256]; - private int[] b = new int[256]; - - protected BlockFire() { - super(Material.FIRE); - this.a(true); - } - - public static void e() { - Blocks.FIRE.a(getId(Blocks.WOOD), 5, 20); - Blocks.FIRE.a(getId(Blocks.WOOD_DOUBLE_STEP), 5, 20); - Blocks.FIRE.a(getId(Blocks.WOOD_STEP), 5, 20); - Blocks.FIRE.a(getId(Blocks.FENCE), 5, 20); - Blocks.FIRE.a(getId(Blocks.WOOD_STAIRS), 5, 20); - Blocks.FIRE.a(getId(Blocks.BIRCH_WOOD_STAIRS), 5, 20); - Blocks.FIRE.a(getId(Blocks.SPRUCE_WOOD_STAIRS), 5, 20); - Blocks.FIRE.a(getId(Blocks.JUNGLE_WOOD_STAIRS), 5, 20); - Blocks.FIRE.a(getId(Blocks.LOG), 5, 5); - Blocks.FIRE.a(getId(Blocks.LOG2), 5, 5); - Blocks.FIRE.a(getId(Blocks.LEAVES), 30, 60); - Blocks.FIRE.a(getId(Blocks.LEAVES2), 30, 60); - Blocks.FIRE.a(getId(Blocks.BOOKSHELF), 30, 20); - Blocks.FIRE.a(getId(Blocks.TNT), 15, 100); - Blocks.FIRE.a(getId(Blocks.LONG_GRASS), 60, 100); - Blocks.FIRE.a(getId(Blocks.DOUBLE_PLANT), 60, 100); - Blocks.FIRE.a(getId(Blocks.YELLOW_FLOWER), 60, 100); - Blocks.FIRE.a(getId(Blocks.RED_ROSE), 60, 100); - Blocks.FIRE.a(getId(Blocks.WOOL), 30, 60); - Blocks.FIRE.a(getId(Blocks.VINE), 15, 100); - Blocks.FIRE.a(getId(Blocks.COAL_BLOCK), 5, 5); - Blocks.FIRE.a(getId(Blocks.HAY_BLOCK), 60, 20); - Blocks.FIRE.a(getId(Blocks.WOOL_CARPET), 60, 20); - } - - public void a(int i, int j, int k) { - this.a[i] = j; - this.b[i] = k; - } - - public AxisAlignedBB a(World world, int i, int j, int k) { - return null; - } - - public boolean c() { - return false; - } - - public boolean d() { - return false; - } - - public int b() { - return 3; - } - - public int a(Random random) { - return 0; - } - - public int a(World world) { - return 30; - } - - public void a(World world, int i, int j, int k, Random random) { - if (world.getGameRules().getBoolean("doFireTick")) { - boolean flag = world.getType(i, j - 1, k) == Blocks.NETHERRACK; - - if (world.worldProvider instanceof WorldProviderTheEnd && world.getType(i, j - 1, k) == Blocks.BEDROCK) { - flag = true; - } - - if (!this.canPlace(world, i, j, k)) { - fireExtinguished(world, i, j, k); // CraftBukkit - invalid place location - } - - if (!flag && world.Q() && (world.isRainingAt(i, j, k) || world.isRainingAt(i - 1, j, k) || world.isRainingAt(i + 1, j, k) || world.isRainingAt(i, j, k - 1) || world.isRainingAt(i, j, k + 1))) { - fireExtinguished(world, i, j, k); // CraftBukkit - extinguished by rain - } else { - int l = world.getData(i, j, k); - - if (l < 15) { - world.setData(i, j, k, l + random.nextInt(3) / 2, 4); - } - - world.a(i, j, k, this, this.a(world) + random.nextInt(10)); - if (!flag && !this.e(world, i, j, k)) { - if (!World.a((IBlockAccess) world, i, j - 1, k) || l > 3) { - fireExtinguished(world, i, j, k); // CraftBukkit - burn out of inflammable block - } - } else if (!flag && !this.e((IBlockAccess) world, i, j - 1, k) && l == 15 && random.nextInt(4) == 0) { - fireExtinguished(world, i, j, k); // CraftBukkit - burn out - } else { - boolean flag1 = world.z(i, j, k); - byte b0 = 0; - - if (flag1) { - b0 = -50; - } - - this.a(world, i + 1, j, k, 300 + b0, random, l); - this.a(world, i - 1, j, k, 300 + b0, random, l); - this.a(world, i, j - 1, k, 250 + b0, random, l); - this.a(world, i, j + 1, k, 250 + b0, random, l); - this.a(world, i, j, k - 1, 300 + b0, random, l); - this.a(world, i, j, k + 1, 300 + b0, random, l); - - for (int i1 = i - 1; i1 <= i + 1; ++i1) { - for (int j1 = k - 1; j1 <= k + 1; ++j1) { - for (int k1 = j - 1; k1 <= j + 4; ++k1) { - if (i1 != i || k1 != j || j1 != k) { - int l1 = 100; - - if (k1 > j + 1) { - l1 += (k1 - (j + 1)) * 100; - } - - int i2 = this.m(world, i1, k1, j1); - - if (i2 > 0) { - int j2 = (i2 + 40 + world.difficulty.a() * 7) / (l + 30); - - if (flag1) { - j2 /= 2; - } - - if (j2 > 0 && random.nextInt(l1) <= j2 && (!world.Q() || !world.isRainingAt(i1, k1, j1)) && !world.isRainingAt(i1 - 1, k1, k) && !world.isRainingAt(i1 + 1, k1, j1) && !world.isRainingAt(i1, k1, j1 - 1) && !world.isRainingAt(i1, k1, j1 + 1)) { - int k2 = l + random.nextInt(5) / 4; - - if (k2 > 15) { - k2 = 15; - } - - // CraftBukkit start - Call to stop spread of fire - if (world.getType(i1, k1, j1) != Blocks.FIRE) { - if (CraftEventFactory.callBlockIgniteEvent(world, i1, k1, j1, i, j, k).isCancelled()) { - continue; - } - - org.bukkit.Server server = world.getServer(); - org.bukkit.World bworld = world.getWorld(); - org.bukkit.block.BlockState blockState = bworld.getBlockAt(i1, k1, j1).getState(); - blockState.setTypeId(Block.getId(this)); - blockState.setData(new org.bukkit.material.MaterialData(Block.getId(this), (byte) k2)); - - BlockSpreadEvent spreadEvent = new BlockSpreadEvent(blockState.getBlock(), bworld.getBlockAt(i, j, k), blockState); - server.getPluginManager().callEvent(spreadEvent); - - if (!spreadEvent.isCancelled()) { - blockState.update(true); - } - } - // CraftBukkit end - } - } - } - } - } - } - } - } - } - } - - public boolean L() { - return false; - } - - private void a(World world, int i, int j, int k, int l, Random random, int i1) { - int j1 = this.b[Block.getId(world.getType(i, j, k))]; - - if (random.nextInt(l) < j1) { - boolean flag = world.getType(i, j, k) == Blocks.TNT; - - // CraftBukkit start - org.bukkit.block.Block theBlock = world.getWorld().getBlockAt(i, j, k); - - BlockBurnEvent event = new BlockBurnEvent(theBlock); - world.getServer().getPluginManager().callEvent(event); - - if (event.isCancelled()) { - return; - } - // CraftBukkit end - - if (random.nextInt(i1 + 10) < 5 && !world.isRainingAt(i, j, k)) { - int k1 = i1 + random.nextInt(5) / 4; - - if (k1 > 15) { - k1 = 15; - } - - world.setTypeAndData(i, j, k, this, k1, 3); - } else { - world.setAir(i, j, k); - } - - if (flag) { - Blocks.TNT.postBreak(world, i, j, k, 1); - } - } - } - - private boolean e(World world, int i, int j, int k) { - return this.e((IBlockAccess) world, i + 1, j, k) ? true : (this.e((IBlockAccess) world, i - 1, j, k) ? true : (this.e((IBlockAccess) world, i, j - 1, k) ? true : (this.e((IBlockAccess) world, i, j + 1, k) ? true : (this.e((IBlockAccess) world, i, j, k - 1) ? true : this.e((IBlockAccess) world, i, j, k + 1))))); - } - - private int m(World world, int i, int j, int k) { - byte b0 = 0; - - if (!world.isEmpty(i, j, k)) { - return 0; - } else { - int l = this.a(world, i + 1, j, k, b0); - - l = this.a(world, i - 1, j, k, l); - l = this.a(world, i, j - 1, k, l); - l = this.a(world, i, j + 1, k, l); - l = this.a(world, i, j, k - 1, l); - l = this.a(world, i, j, k + 1, l); - return l; - } - } - - public boolean v() { - return false; - } - - public boolean e(IBlockAccess iblockaccess, int i, int j, int k) { - return this.a[Block.getId(iblockaccess.getType(i, j, k))] > 0; - } - - public int a(World world, int i, int j, int k, int l) { - int i1 = this.a[Block.getId(world.getType(i, j, k))]; - - return i1 > l ? i1 : l; - } - - public boolean canPlace(World world, int i, int j, int k) { - return World.a((IBlockAccess) world, i, j - 1, k) || this.e(world, i, j, k); - } - - public void doPhysics(World world, int i, int j, int k, Block block) { - if (!World.a((IBlockAccess) world, i, j - 1, k) && !this.e(world, i, j, k)) { - fireExtinguished(world, i, j, k); // CraftBukkit - fuel block gone - } - } - - public void onPlace(World world, int i, int j, int k) { - if (world.worldProvider.dimension > 0 || !Blocks.PORTAL.e(world, i, j, k)) { - if (!World.a((IBlockAccess) world, i, j - 1, k) && !this.e(world, i, j, k)) { - fireExtinguished(world, i, j, k); // CraftBukkit - fuel block broke - } else { - world.a(i, j, k, this, this.a(world) + world.random.nextInt(10)); - } - } - } - - public MaterialMapColor f(int i) { - return MaterialMapColor.f; - } - - // CraftBukkit start - private void fireExtinguished(World world, int x, int y, int z) { - if (!CraftEventFactory.callBlockFadeEvent(world.getWorld().getBlockAt(x, y, z), Blocks.AIR).isCancelled()) { - world.setAir(x, y, z); - } - } - // CraftBukkit end -} |