diff options
author | EvilSeph <evilseph@unaligned.org> | 2011-05-15 23:52:11 -0400 |
---|---|---|
committer | EvilSeph <evilseph@unaligned.org> | 2011-05-15 23:52:11 -0400 |
commit | 27e75c358d4704afed39c20bbdaf07dd39209d67 (patch) | |
tree | d8d5a06e29d195c3d08031dae31358ae55054f8c /src/main/java | |
parent | a4570215fd298683d8730b6d3cda000a1c5a059c (diff) | |
download | craftbukkit-27e75c358d4704afed39c20bbdaf07dd39209d67.tar craftbukkit-27e75c358d4704afed39c20bbdaf07dd39209d67.tar.gz craftbukkit-27e75c358d4704afed39c20bbdaf07dd39209d67.tar.lz craftbukkit-27e75c358d4704afed39c20bbdaf07dd39209d67.tar.xz craftbukkit-27e75c358d4704afed39c20bbdaf07dd39209d67.zip |
Fixed trees being invisible under certain circumstances. Thanks Zeerix!
Diffstat (limited to 'src/main/java')
-rw-r--r-- | src/main/java/net/minecraft/server/BlockSapling.java | 84 |
1 files changed, 84 insertions, 0 deletions
diff --git a/src/main/java/net/minecraft/server/BlockSapling.java b/src/main/java/net/minecraft/server/BlockSapling.java new file mode 100644 index 00000000..2f2fae00 --- /dev/null +++ b/src/main/java/net/minecraft/server/BlockSapling.java @@ -0,0 +1,84 @@ +package net.minecraft.server; + +import java.util.Random; + +import org.bukkit.BlockChangeDelegate; // CraftBukkit + +public class BlockSapling extends BlockFlower { + + protected BlockSapling(int i, int j) { + super(i, j); + float f = 0.4F; + + this.a(0.5F - f, 0.0F, 0.5F - f, 0.5F + f, f * 2.0F, 0.5F + f); + } + + public void a(World world, int i, int j, int k, Random random) { + super.a(world, i, j, k, random); + if (world.getLightLevel(i, j + 1, k) >= 9 && random.nextInt(30) == 0) { + int l = world.getData(i, j, k); + + if ((l & 8) == 0) { + world.setData(i, j, k, l | 8); + } else { + this.b(world, i, j, k, random); + } + } + } + + public int a(int i, int j) { + j &= 3; + return j == 1 ? 63 : (j == 2 ? 79 : super.a(i, j)); + } + + public void b(World world, int i, int j, int k, Random random) { + int l = world.getData(i, j, k) & 3; + + world.setRawTypeId(i, j, k, 0); + + // CraftBukkit start - fixes client updates on recently grown trees + boolean grownTree; + BlockChangeWithNotify delegate = new BlockChangeWithNotify(world); + + if (l == 1) { + grownTree = new WorldGenTaiga2().generate(delegate, random, i, j, k); + } else if (l == 2) { + grownTree = new WorldGenForest().generate(delegate, random, i, j, k); + } else { + if (random.nextInt(10) == 0) { + grownTree = new WorldGenBigTree().generate(delegate, random, i, j, k); + } else { + grownTree = new WorldGenTrees().generate(delegate, random, i, j, k); + } + } + + if (!grownTree) { + world.setRawTypeIdAndData(i, j, k, this.id, l); + } + // CraftBukkit end + } + + protected int b(int i) { + return i & 3; + } + + // CraftBukkit start + private class BlockChangeWithNotify implements BlockChangeDelegate { + World world; + + BlockChangeWithNotify(World world) { this.world = world; } + + public boolean setRawTypeId(int x, int y, int z, int type) { + return world.setTypeId(x, y, z, type); + } + + public boolean setRawTypeIdAndData(int x, int y, int z, int type, int data) { + return world.setTypeIdAndData(x, y, z, type, data); + } + + public int getTypeId(int x, int y, int z) { + return world.getTypeId(x, y, z); + } + } + // CraftBukkit end +} |