From aa3678a7837646eb7c0c091fdaf5674b76634788 Mon Sep 17 00:00:00 2001 From: Nathan Adams Date: Thu, 1 Mar 2012 15:10:06 +0000 Subject: Fixed NoSuchMethodError in WorldGenGroundBush --- .../net/minecraft/server/WorldGenGroundBush.java | 56 ++++++++++++++++++++++ 1 file changed, 56 insertions(+) create mode 100644 src/main/java/net/minecraft/server/WorldGenGroundBush.java (limited to 'src/main/java/net/minecraft/server') diff --git a/src/main/java/net/minecraft/server/WorldGenGroundBush.java b/src/main/java/net/minecraft/server/WorldGenGroundBush.java new file mode 100644 index 00000000..3b21c52f --- /dev/null +++ b/src/main/java/net/minecraft/server/WorldGenGroundBush.java @@ -0,0 +1,56 @@ +package net.minecraft.server; + +import java.util.Random; + +import org.bukkit.BlockChangeDelegate; // CraftBukkit + +public class WorldGenGroundBush extends WorldGenerator { + + private int a; + private int b; + + public WorldGenGroundBush(int i, int j) { + this.b = i; + this.a = j; + } + + public boolean a(World world, Random random, int i, int j, int k) { + // CraftBukkit start + return this.generate((BlockChangeDelegate) world, random, i, j, k); + } + + public boolean generate(BlockChangeDelegate world, Random random, int i, int j, int k) { + // CraftBukkit end + int l; + + for (boolean flag = false; ((l = world.getTypeId(i, j, k)) == 0 || l == Block.LEAVES.id) && j > 0; --j) { + ; + } + + int i1 = world.getTypeId(i, j, k); + + if (i1 == Block.DIRT.id || i1 == Block.GRASS.id) { + ++j; + world.setRawTypeIdAndData(i, j, k, Block.LOG.id, this.b); + + for (int j1 = j; j1 <= j + 2; ++j1) { + int k1 = j1 - j; + int l1 = 2 - k1; + + for (int i2 = i - l1; i2 <= i + l1; ++i2) { + int j2 = i2 - i; + + for (int k2 = k - l1; k2 <= k + l1; ++k2) { + int l2 = k2 - k; + + if ((Math.abs(j2) != l1 || Math.abs(l2) != l1 || random.nextInt(2) != 0) && !Block.n[world.getTypeId(i2, j1, k2)]) { + this.setTypeAndData(world, i2, j1, k2, Block.LEAVES.id, this.a); + } + } + } + } + } + + return true; + } +} -- cgit v1.2.3