summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authormd_5 <md_5@bigpond.com>2012-03-16 17:32:25 +1100
committerEvilSeph <evilseph@gmail.com>2012-03-20 06:38:03 -0400
commit7966531113ded3d91144bdafff9674e32e468333 (patch)
treea08615976c68652aee92c42f940a5120e80208b2
parentea60181a87dd8ca47e5c0742a3b6a8dc5178a870 (diff)
downloadcraftbukkit-7966531113ded3d91144bdafff9674e32e468333.tar
craftbukkit-7966531113ded3d91144bdafff9674e32e468333.tar.gz
craftbukkit-7966531113ded3d91144bdafff9674e32e468333.tar.lz
craftbukkit-7966531113ded3d91144bdafff9674e32e468333.tar.xz
craftbukkit-7966531113ded3d91144bdafff9674e32e468333.zip
[Bleeding] Completely fix the tree generation algorithm to make it near identical to vanilla as well as fix potential bugs associated with disappearing saplings.
-rw-r--r--src/main/java/net/minecraft/server/BlockSapling.java72
-rw-r--r--src/main/java/net/minecraft/server/WorldGenBigTree.java2
-rw-r--r--src/main/java/net/minecraft/server/WorldGenForest.java2
-rw-r--r--src/main/java/net/minecraft/server/WorldGenMegaTree.java2
-rw-r--r--src/main/java/net/minecraft/server/WorldGenTaiga1.java2
-rw-r--r--src/main/java/net/minecraft/server/WorldGenTaiga2.java2
-rw-r--r--src/main/java/net/minecraft/server/WorldGenTrees.java2
7 files changed, 49 insertions, 35 deletions
diff --git a/src/main/java/net/minecraft/server/BlockSapling.java b/src/main/java/net/minecraft/server/BlockSapling.java
index a22aac91..3f437bea 100644
--- a/src/main/java/net/minecraft/server/BlockSapling.java
+++ b/src/main/java/net/minecraft/server/BlockSapling.java
@@ -2,6 +2,7 @@ package net.minecraft.server;
import java.util.Random;
// CraftBukkit start
+import org.bukkit.BlockChangeDelegate;
import org.bukkit.Bukkit;
import org.bukkit.Location;
import org.bukkit.TreeType;
@@ -43,56 +44,61 @@ public class BlockSapling extends BlockFlower {
// CraftBukkit - added bonemeal, player and itemstack
public void grow(World world, int i, int j, int k, Random random, boolean bonemeal, Player player, ItemStack itemstack) {
int l = world.getData(i, j, k) & 3;
-
- // CraftBukkit start - records tree generation and calls StructureGrowEvent
- StructureGrowDelegate delegate = new StructureGrowDelegate(world);
- TreeType treeType;
int i1 = 0;
int j1 = 0;
+ // CraftBukkit start - records tree generation and calls StructureGrowEvent
+ StructureGrowDelegate delegate = new StructureGrowDelegate(world);
+ TreeType treeType = null;
+ TreeGenerator gen = null;
boolean grownTree = false;
- boolean megaTree = false;
- // All of these are 'false' because we need the 'raw' calls so the block-delegate works
+ boolean flag = false;
+
if (l == 1) {
treeType = TreeType.REDWOOD;
- world.setRawTypeId(i, j, k, 0);
- grownTree = new WorldGenTaiga2(false).generate(delegate, random, i, j, k);
+ gen = new WorldGenTaiga2(false);
} else if (l == 2) {
treeType = TreeType.BIRCH;
- world.setRawTypeId(i, j, k, 0);
- grownTree = new WorldGenForest(false).generate(delegate, random, i, j, k);
+ gen = new WorldGenForest(false);
} else if (l == 3) {
- treeType = TreeType.JUNGLE;
for (i1 = 0; i1 >= -1; --i1) {
for (j1 = 0; j1 >= -1; --j1) {
if (world.getTypeId(i + i1, j, k + j1) == this.id && world.getTypeId(i + i1 + 1, j, k + j1) == this.id && world.getTypeId(i + i1, j, k + j1 + 1) == this.id && world.getTypeId(i + i1 + 1, j, k + j1 + 1) == this.id) {
- world.setRawTypeId(i + i1, j, k + j1, 0);
- world.setRawTypeId(i + i1 + 1, j, k + j1, 0);
- world.setRawTypeId(i + i1, j, k + j1 + 1, 0);
- world.setRawTypeId(i + i1 + 1, j, k + j1 + 1, 0);
- grownTree = new WorldGenMegaTree(false, 10 + random.nextInt(20), 3, 3).generate(delegate, random, i + i1, j, k + j1);
- megaTree = true;
+ treeType = TreeType.JUNGLE;
+ gen = new WorldGenMegaTree(false, 10 + random.nextInt(20), 3, 3);
+ flag = true;
break;
}
}
+
+ if (gen != null) {
+ break;
+ }
}
- if (!grownTree) {
+
+ if (gen == null) {
j1 = 0;
i1 = 0;
- world.setRawTypeId(i, j, k, 0);
- grownTree = new WorldGenTrees(false, 4 + random.nextInt(7), 3, 3, false).generate(delegate, random, i, j, k);
+ treeType = TreeType.TREE;
+ gen = new WorldGenTrees(false, 4 + random.nextInt(7), 3, 3, false);
}
} else {
+ treeType = TreeType.TREE;
+ gen = new WorldGenTrees(false);
if (random.nextInt(10) == 0) {
treeType = TreeType.BIG_TREE;
- world.setRawTypeId(i, j, k, 0);
- grownTree = new WorldGenBigTree(false).generate(delegate, random, i, j, k);
- } else {
- treeType = TreeType.TREE;
- world.setRawTypeId(i, j, k, 0);
- grownTree = new WorldGenTrees(false).generate(delegate, random, i, j, k);
+ gen = new WorldGenBigTree(false);
}
}
+ if (flag) {
+ world.setRawTypeId(i + i1, j, k + j1, 0);
+ world.setRawTypeId(i + i1 + 1, j, k + j1, 0);
+ world.setRawTypeId(i + i1, j, k + j1 + 1, 0);
+ world.setRawTypeId(i + i1 + 1, j, k + j1 + 1, 0);
+ } else {
+ world.setRawTypeId(i, j, k, 0);
+ }
+ grownTree = gen.generate(delegate, random, i + i1, j, k + j1);
if (grownTree) {
Location location = new Location(world.getWorld(), i, j, k);
StructureGrowEvent event = new StructureGrowEvent(location, treeType, bonemeal, player, delegate.getBlocks());
@@ -108,10 +114,8 @@ public class BlockSapling extends BlockFlower {
}
}
}
-
if (!grownTree) {
- if (megaTree) {
- // CraftBukkit end
+ if (flag) {
world.setRawTypeIdAndData(i + i1, j, k + j1, this.id, l);
world.setRawTypeIdAndData(i + i1 + 1, j, k + j1, this.id, l);
world.setRawTypeIdAndData(i + i1, j, k + j1 + 1, this.id, l);
@@ -120,9 +124,19 @@ public class BlockSapling extends BlockFlower {
world.setRawTypeIdAndData(i, j, k, this.id, l);
}
}
+ // CraftBukkit end
}
protected int getDropData(int i) {
return i & 3;
}
+
+ // CraftBukkit start
+ interface TreeGenerator {
+
+ public boolean a(World world, Random random, int i, int j, int k);
+
+ public boolean generate(BlockChangeDelegate world, Random random, int i, int j, int k);
+ }
+ // CraftBukkit end
}
diff --git a/src/main/java/net/minecraft/server/WorldGenBigTree.java b/src/main/java/net/minecraft/server/WorldGenBigTree.java
index c4d3f17a..864ab1c7 100644
--- a/src/main/java/net/minecraft/server/WorldGenBigTree.java
+++ b/src/main/java/net/minecraft/server/WorldGenBigTree.java
@@ -4,7 +4,7 @@ import java.util.Random;
import org.bukkit.BlockChangeDelegate; // CraftBukkit
-public class WorldGenBigTree extends WorldGenerator {
+public class WorldGenBigTree extends WorldGenerator implements BlockSapling.TreeGenerator { // CraftBukkit add interface
static final byte[] a = new byte[] { (byte) 2, (byte) 0, (byte) 0, (byte) 1, (byte) 2, (byte) 1};
Random b = new Random();
diff --git a/src/main/java/net/minecraft/server/WorldGenForest.java b/src/main/java/net/minecraft/server/WorldGenForest.java
index 0ea716f7..a792b1ed 100644
--- a/src/main/java/net/minecraft/server/WorldGenForest.java
+++ b/src/main/java/net/minecraft/server/WorldGenForest.java
@@ -4,7 +4,7 @@ import java.util.Random;
import org.bukkit.BlockChangeDelegate; // CraftBukkit
-public class WorldGenForest extends WorldGenerator {
+public class WorldGenForest extends WorldGenerator implements BlockSapling.TreeGenerator { // CraftBukkit add interface
public WorldGenForest(boolean flag) {
super(flag);
diff --git a/src/main/java/net/minecraft/server/WorldGenMegaTree.java b/src/main/java/net/minecraft/server/WorldGenMegaTree.java
index 0a9da965..736e63b3 100644
--- a/src/main/java/net/minecraft/server/WorldGenMegaTree.java
+++ b/src/main/java/net/minecraft/server/WorldGenMegaTree.java
@@ -4,7 +4,7 @@ import java.util.Random;
import org.bukkit.BlockChangeDelegate; // CraftBukkit
-public class WorldGenMegaTree extends WorldGenerator {
+public class WorldGenMegaTree extends WorldGenerator implements BlockSapling.TreeGenerator { // CraftBukkit add interface
private final int a;
private final int b;
diff --git a/src/main/java/net/minecraft/server/WorldGenTaiga1.java b/src/main/java/net/minecraft/server/WorldGenTaiga1.java
index 2a828805..edd3056c 100644
--- a/src/main/java/net/minecraft/server/WorldGenTaiga1.java
+++ b/src/main/java/net/minecraft/server/WorldGenTaiga1.java
@@ -4,7 +4,7 @@ import java.util.Random;
import org.bukkit.BlockChangeDelegate; // CraftBukkit
-public class WorldGenTaiga1 extends WorldGenerator {
+public class WorldGenTaiga1 extends WorldGenerator implements BlockSapling.TreeGenerator { // CraftBukkit add interface
public WorldGenTaiga1() {}
diff --git a/src/main/java/net/minecraft/server/WorldGenTaiga2.java b/src/main/java/net/minecraft/server/WorldGenTaiga2.java
index 34367ab9..0f3a6d6f 100644
--- a/src/main/java/net/minecraft/server/WorldGenTaiga2.java
+++ b/src/main/java/net/minecraft/server/WorldGenTaiga2.java
@@ -4,7 +4,7 @@ import java.util.Random;
import org.bukkit.BlockChangeDelegate; // CraftBukkit
-public class WorldGenTaiga2 extends WorldGenerator {
+public class WorldGenTaiga2 extends WorldGenerator implements BlockSapling.TreeGenerator { // CraftBukkit add interface
public WorldGenTaiga2(boolean flag) {
super(flag);
diff --git a/src/main/java/net/minecraft/server/WorldGenTrees.java b/src/main/java/net/minecraft/server/WorldGenTrees.java
index 8bf16cd4..bc8f8fac 100644
--- a/src/main/java/net/minecraft/server/WorldGenTrees.java
+++ b/src/main/java/net/minecraft/server/WorldGenTrees.java
@@ -4,7 +4,7 @@ import java.util.Random;
import org.bukkit.BlockChangeDelegate; // CraftBukkit
-public class WorldGenTrees extends WorldGenerator {
+public class WorldGenTrees extends WorldGenerator implements BlockSapling.TreeGenerator { // CraftBukkit add interface
private final int a;
private final boolean b;