summaryrefslogtreecommitdiffstats
path: root/src/main/java/net/minecraft/server/BlockStem.java
diff options
context:
space:
mode:
Diffstat (limited to 'src/main/java/net/minecraft/server/BlockStem.java')
-rw-r--r--src/main/java/net/minecraft/server/BlockStem.java98
1 files changed, 55 insertions, 43 deletions
diff --git a/src/main/java/net/minecraft/server/BlockStem.java b/src/main/java/net/minecraft/server/BlockStem.java
index f2d4e578..4fae805b 100644
--- a/src/main/java/net/minecraft/server/BlockStem.java
+++ b/src/main/java/net/minecraft/server/BlockStem.java
@@ -4,48 +4,48 @@ import java.util.Random;
import org.bukkit.craftbukkit.event.CraftEventFactory; // CraftBukkit
-public class BlockStem extends BlockFlower {
+public class BlockStem extends BlockPlant implements IBlockFragilePlantElement {
private final Block blockFruit;
- protected BlockStem(int i, Block block) {
- super(i);
+ protected BlockStem(Block block) {
this.blockFruit = block;
- this.b(true);
+ this.a(true);
float f = 0.125F;
this.a(0.5F - f, 0.0F, 0.5F - f, 0.5F + f, 0.25F, 0.5F + f);
this.a((CreativeModeTab) null);
}
- protected boolean g_(int i) {
- return i == Block.SOIL.id;
+ protected boolean a(Block block) {
+ return block == Blocks.SOIL;
}
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) {
- float f = this.m(world, i, j, k);
+ float f = this.n(world, i, j, k);
if (random.nextInt((int) (25.0F / f) + 1) == 0) {
int l = world.getData(i, j, k);
if (l < 7) {
- CraftEventFactory.handleBlockGrowEvent(world, i, j, k, this.id, ++l); // CraftBukkit
+ ++l;
+ CraftEventFactory.handleBlockGrowEvent(world, i, j, k, this, l); // CraftBukkit
} else {
- if (world.getTypeId(i - 1, j, k) == this.blockFruit.id) {
+ if (world.getType(i - 1, j, k) == this.blockFruit) {
return;
}
- if (world.getTypeId(i + 1, j, k) == this.blockFruit.id) {
+ if (world.getType(i + 1, j, k) == this.blockFruit) {
return;
}
- if (world.getTypeId(i, j, k - 1) == this.blockFruit.id) {
+ if (world.getType(i, j, k - 1) == this.blockFruit) {
return;
}
- if (world.getTypeId(i, j, k + 1) == this.blockFruit.id) {
+ if (world.getType(i, j, k + 1) == this.blockFruit) {
return;
}
@@ -69,17 +69,17 @@ public class BlockStem extends BlockFlower {
++k1;
}
- int l1 = world.getTypeId(j1, j - 1, k1);
+ Block block = world.getType(j1, j - 1, k1);
- if (world.getTypeId(j1, j, k1) == 0 && (l1 == Block.SOIL.id || l1 == Block.DIRT.id || l1 == Block.GRASS.id)) {
- CraftEventFactory.handleBlockGrowEvent(world, j1, j, k1, this.blockFruit.id, 0); // CraftBukkit
+ if (world.getType(j1, j, k1).material == Material.AIR && (block == Blocks.SOIL || block == Blocks.DIRT || block == Blocks.GRASS)) {
+ CraftEventFactory.handleBlockGrowEvent(world, j1, j, k1, this.blockFruit, 0); // CraftBukkit
}
}
}
}
}
- public void k(World world, int i, int j, int k) {
+ public void m(World world, int i, int j, int k) {
int l = world.getData(i, j, k) + MathHelper.nextInt(world.random, 2, 5);
if (l > 7) {
@@ -89,33 +89,33 @@ public class BlockStem extends BlockFlower {
world.setData(i, j, k, l, 2);
}
- private float m(World world, int i, int j, int k) {
+ private float n(World world, int i, int j, int k) {
float f = 1.0F;
- int l = world.getTypeId(i, j, k - 1);
- int i1 = world.getTypeId(i, j, k + 1);
- int j1 = world.getTypeId(i - 1, j, k);
- int k1 = world.getTypeId(i + 1, j, k);
- int l1 = world.getTypeId(i - 1, j, k - 1);
- int i2 = world.getTypeId(i + 1, j, k - 1);
- int j2 = world.getTypeId(i + 1, j, k + 1);
- int k2 = world.getTypeId(i - 1, j, k + 1);
- boolean flag = j1 == this.id || k1 == this.id;
- boolean flag1 = l == this.id || i1 == this.id;
- boolean flag2 = l1 == this.id || i2 == this.id || j2 == this.id || k2 == this.id;
-
- for (int l2 = i - 1; l2 <= i + 1; ++l2) {
- for (int i3 = k - 1; i3 <= k + 1; ++i3) {
- int j3 = world.getTypeId(l2, j - 1, i3);
+ Block block = world.getType(i, j, k - 1);
+ Block block1 = world.getType(i, j, k + 1);
+ Block block2 = world.getType(i - 1, j, k);
+ Block block3 = world.getType(i + 1, j, k);
+ Block block4 = world.getType(i - 1, j, k - 1);
+ Block block5 = world.getType(i + 1, j, k - 1);
+ Block block6 = world.getType(i + 1, j, k + 1);
+ Block block7 = world.getType(i - 1, j, k + 1);
+ boolean flag = block2 == this || block3 == this;
+ boolean flag1 = block == this || block1 == this;
+ boolean flag2 = block4 == this || block5 == this || block6 == this || block7 == this;
+
+ for (int l = i - 1; l <= i + 1; ++l) {
+ for (int i1 = k - 1; i1 <= k + 1; ++i1) {
+ Block block8 = world.getType(l, j - 1, i1);
float f1 = 0.0F;
- if (j3 == Block.SOIL.id) {
+ if (block8 == Blocks.SOIL) {
f1 = 1.0F;
- if (world.getData(l2, j - 1, i3) > 0) {
+ if (world.getData(l, j - 1, i1) > 0) {
f1 = 3.0F;
}
}
- if (l2 != i || i3 != k) {
+ if (l != i || i1 != k) {
f1 /= 4.0F;
}
@@ -143,7 +143,7 @@ public class BlockStem extends BlockFlower {
this.a(0.5F - f, 0.0F, 0.5F - f, 0.5F + f, (float) this.maxY, 0.5F + f);
}
- public int d() {
+ public int b() {
return 19;
}
@@ -152,27 +152,39 @@ public class BlockStem extends BlockFlower {
if (!world.isStatic) {
Item item = null;
- if (this.blockFruit == Block.PUMPKIN) {
- item = Item.PUMPKIN_SEEDS;
+ if (this.blockFruit == Blocks.PUMPKIN) {
+ item = Items.PUMPKIN_SEEDS;
}
- if (this.blockFruit == Block.MELON) {
- item = Item.MELON_SEEDS;
+ if (this.blockFruit == Blocks.MELON) {
+ item = Items.MELON_SEEDS;
}
for (int j1 = 0; j1 < 3; ++j1) {
if (world.random.nextInt(15) <= l) {
- this.b(world, i, j, k, new ItemStack(item));
+ this.a(world, i, j, k, new ItemStack(item));
}
}
}
}
- public int getDropType(int i, Random random, int j) {
- return -1;
+ public Item getDropType(int i, Random random, int j) {
+ return null;
}
public int a(Random random) {
return 1;
}
+
+ public boolean a(World world, int i, int j, int k, boolean flag) {
+ return world.getData(i, j, k) != 7;
+ }
+
+ public boolean a(World world, Random random, int i, int j, int k) {
+ return true;
+ }
+
+ public void b(World world, Random random, int i, int j, int k) {
+ this.m(world, i, j, k);
+ }
}