summaryrefslogtreecommitdiffstats
path: root/src/main/java/net/minecraft/server/BlockSapling.java
diff options
context:
space:
mode:
authorEvilSeph <evilseph@unaligned.org>2011-05-15 23:52:11 -0400
committerEvilSeph <evilseph@unaligned.org>2011-05-15 23:52:11 -0400
commit27e75c358d4704afed39c20bbdaf07dd39209d67 (patch)
treed8d5a06e29d195c3d08031dae31358ae55054f8c /src/main/java/net/minecraft/server/BlockSapling.java
parenta4570215fd298683d8730b6d3cda000a1c5a059c (diff)
downloadcraftbukkit-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/net/minecraft/server/BlockSapling.java')
-rw-r--r--src/main/java/net/minecraft/server/BlockSapling.java84
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
+}