summaryrefslogtreecommitdiffstats
path: root/src/main/java/net/minecraft/server/BlockSnow.java
diff options
context:
space:
mode:
authorTravis Watkins <amaranth@ubuntu.com>2013-03-13 17:33:27 -0500
committerTravis Watkins <amaranth@ubuntu.com>2013-03-15 13:28:59 -0500
commit83d29e461c85733f0113b6eb19db6e3b42da2949 (patch)
treeb3063a1c28f478ab368d5ba3413a842def68c28f /src/main/java/net/minecraft/server/BlockSnow.java
parentba6e4c38cfa98ad291974195cc46d70a4f138ac1 (diff)
downloadcraftbukkit-83d29e461c85733f0113b6eb19db6e3b42da2949.tar
craftbukkit-83d29e461c85733f0113b6eb19db6e3b42da2949.tar.gz
craftbukkit-83d29e461c85733f0113b6eb19db6e3b42da2949.tar.lz
craftbukkit-83d29e461c85733f0113b6eb19db6e3b42da2949.tar.xz
craftbukkit-83d29e461c85733f0113b6eb19db6e3b42da2949.zip
Update CraftBukkit to Minecraft 1.5
Diffstat (limited to 'src/main/java/net/minecraft/server/BlockSnow.java')
-rw-r--r--src/main/java/net/minecraft/server/BlockSnow.java40
1 files changed, 25 insertions, 15 deletions
diff --git a/src/main/java/net/minecraft/server/BlockSnow.java b/src/main/java/net/minecraft/server/BlockSnow.java
index eacb1485..5b913cb2 100644
--- a/src/main/java/net/minecraft/server/BlockSnow.java
+++ b/src/main/java/net/minecraft/server/BlockSnow.java
@@ -4,17 +4,19 @@ import java.util.Random;
public class BlockSnow extends Block {
- protected BlockSnow(int i, int j) {
- super(i, j, Material.SNOW_LAYER);
+ protected BlockSnow(int i) {
+ super(i, Material.SNOW_LAYER);
this.a(0.0F, 0.0F, 0.0F, 1.0F, 0.125F, 1.0F);
this.b(true);
this.a(CreativeModeTab.c);
+ this.d(0);
}
- public AxisAlignedBB e(World world, int i, int j, int k) {
+ public AxisAlignedBB b(World world, int i, int j, int k) {
int l = world.getData(i, j, k) & 7;
+ float f = 0.125F;
- return l >= 3 ? AxisAlignedBB.a().a((double) i + this.minX, (double) j + this.minY, (double) k + this.minZ, (double) i + this.maxX, (double) ((float) j + 0.5F), (double) k + this.maxZ) : null;
+ return AxisAlignedBB.a().a((double) i + this.minX, (double) j + this.minY, (double) k + this.minZ, (double) i + this.maxX, (double) ((float) j + (float) l * f), (double) k + this.maxZ);
}
public boolean c() {
@@ -25,9 +27,17 @@ public class BlockSnow extends Block {
return false;
}
+ public void g() {
+ this.d(0);
+ }
+
public void updateShape(IBlockAccess iblockaccess, int i, int j, int k) {
- int l = iblockaccess.getData(i, j, k) & 7;
- float f = (float) (2 * (1 + l)) / 16.0F;
+ this.d(iblockaccess.getData(i, j, k));
+ }
+
+ protected void d(int i) {
+ int j = i & 7;
+ float f = (float) (2 * (1 + j)) / 16.0F;
this.a(0.0F, 0.0F, 0.0F, 1.0F, f, 1.0F);
}
@@ -35,18 +45,17 @@ public class BlockSnow extends Block {
public boolean canPlace(World world, int i, int j, int k) {
int l = world.getTypeId(i, j - 1, k);
- return l != 0 && (l == Block.LEAVES.id || Block.byId[l].c()) ? world.getMaterial(i, j - 1, k).isSolid() : false;
+ return l == 0 ? false : (l == this.id && (world.getData(i, j - 1, k) & 7) == 7 ? true : (l != Block.LEAVES.id && !Block.byId[l].c() ? false : world.getMaterial(i, j - 1, k).isSolid()));
}
public void doPhysics(World world, int i, int j, int k, int l) {
- this.n(world, i, j, k);
+ this.m(world, i, j, k);
}
- private boolean n(World world, int i, int j, int k) {
+ private boolean m(World world, int i, int j, int k) {
if (!this.canPlace(world, i, j, k)) {
this.c(world, i, j, k, world.getData(i, j, k), 0);
- world.setRawTypeId(i, j, k, 0); // CraftBukkit
- world.notify(i, j, k); // CraftBukkit - Notify clients of the reversion
+ world.setAir(i, j, k);
return false;
} else {
return true;
@@ -55,9 +64,10 @@ public class BlockSnow extends Block {
public void a(World world, EntityHuman entityhuman, int i, int j, int k, int l) {
int i1 = Item.SNOW_BALL.id;
+ int j1 = l & 7;
- this.b(world, i, j, k, new ItemStack(i1, 1, 0));
- world.setTypeId(i, j, k, 0);
+ this.b(world, i, j, k, new ItemStack(i1, j1 + 1, 0));
+ world.setAir(i, j, k);
entityhuman.a(StatisticList.C[this.id], 1);
}
@@ -69,7 +79,7 @@ public class BlockSnow extends Block {
return 0;
}
- public void b(World world, int i, int j, int k, Random random) {
+ public void a(World world, int i, int j, int k, Random random) {
if (world.b(EnumSkyBlock.BLOCK, i, j, k) > 11) {
// CraftBukkit start
if (org.bukkit.craftbukkit.event.CraftEventFactory.callBlockFadeEvent(world.getWorld().getBlockAt(i, j, k), 0).isCancelled()) {
@@ -78,7 +88,7 @@ public class BlockSnow extends Block {
// CraftBukkit end
this.c(world, i, j, k, world.getData(i, j, k), 0);
- world.setTypeId(i, j, k, 0);
+ world.setAir(i, j, k);
}
}
}