diff options
author | Erik Broes <erikbroes@grum.nl> | 2011-01-29 22:50:29 +0100 |
---|---|---|
committer | Erik Broes <erikbroes@grum.nl> | 2011-01-30 13:24:39 +0100 |
commit | df69047324abc54f5d5b8d069bb69b1061b20cce (patch) | |
tree | 76f8d13addf80730deea9285f4bd9a1ffbe45f80 /src/main/java/net/minecraft/server/TileEntityMobSpawner.java | |
parent | d0cd8c6cc7d1aaf38934996e7e5d3e03272e4ff1 (diff) | |
download | craftbukkit-df69047324abc54f5d5b8d069bb69b1061b20cce.tar craftbukkit-df69047324abc54f5d5b8d069bb69b1061b20cce.tar.gz craftbukkit-df69047324abc54f5d5b8d069bb69b1061b20cce.tar.lz craftbukkit-df69047324abc54f5d5b8d069bb69b1061b20cce.tar.xz craftbukkit-df69047324abc54f5d5b8d069bb69b1061b20cce.zip |
Port to new mc-dev format.
Diffstat (limited to 'src/main/java/net/minecraft/server/TileEntityMobSpawner.java')
-rw-r--r-- | src/main/java/net/minecraft/server/TileEntityMobSpawner.java | 136 |
1 files changed, 65 insertions, 71 deletions
diff --git a/src/main/java/net/minecraft/server/TileEntityMobSpawner.java b/src/main/java/net/minecraft/server/TileEntityMobSpawner.java index b3c30623..52f8a302 100644 --- a/src/main/java/net/minecraft/server/TileEntityMobSpawner.java +++ b/src/main/java/net/minecraft/server/TileEntityMobSpawner.java @@ -1,108 +1,102 @@ package net.minecraft.server; -import java.util.List; -import java.util.Random; - public class TileEntityMobSpawner extends TileEntity { - public int e; - public String h; // CraftBukkit -> public + public int e = -1; + public String h = "Pig"; // CraftBukkit private -> public public double f; - public double g; + public double g = 0.0D; public TileEntityMobSpawner() { - e = -1; - g = 0.0D; - h = "Pig"; - e = 20; + this.e = 20; } public void a(String s) { - h = s; + this.h = s; } public boolean a() { - return a.a((double) b + 0.5D, (double) c + 0.5D, (double) d + 0.5D, 16D) != null; + return this.a.a((double) this.b + 0.5D, (double) this.c + 0.5D, (double) this.d + 0.5D, 16.0D) != null; } public void f() { - g = f; - if (!a()) { - return; - } - double d = (float) b + a.l.nextFloat(); - double d2 = (float) c + a.l.nextFloat(); - double d4 = (float) this.d + a.l.nextFloat(); - - a.a("smoke", d, d2, d4, 0.0D, 0.0D, 0.0D); - a.a("flame", d, d2, d4, 0.0D, 0.0D, 0.0D); - for (f += 1000F / ((float) e + 200F); f > 360D;) { - f -= 360D; - g -= 360D; - } - - if (e == -1) { - b(); - } - if (e > 0) { - e--; - return; - } - byte byte0 = 4; + this.g = this.f; + if (this.a()) { + double d0 = (double) ((float) this.b + this.a.l.nextFloat()); + double d1 = (double) ((float) this.c + this.a.l.nextFloat()); + double d2 = (double) ((float) this.d + this.a.l.nextFloat()); - for (int i = 0; i < byte0; i++) { - EntityLiving entityliving = (EntityLiving) EntityList.a(h, a); + this.a.a("smoke", d0, d1, d2, 0.0D, 0.0D, 0.0D); + this.a.a("flame", d0, d1, d2, 0.0D, 0.0D, 0.0D); - if (entityliving == null) { - return; + for (this.f += (double) (1000.0F / ((float) this.e + 200.0F)); this.f > 360.0D; this.g -= 360.0D) { + this.f -= 360.0D; } - int j = a.a(((entityliving)).getClass(), AxisAlignedBB.b(b, c, this.d, b + 1, c + 1, this.d + 1).b(8D, 4D, 8D)).size(); - if (j >= 6) { - b(); - return; - } - if (entityliving == null) { - continue; + if (this.e == -1) { + this.b(); } - double d6 = (double) b + (a.l.nextDouble() - a.l.nextDouble()) * 4D; - double d7 = (c + a.l.nextInt(3)) - 1; - double d8 = (double) this.d + (a.l.nextDouble() - a.l.nextDouble()) * 4D; - entityliving.c(d6, d7, d8, a.l.nextFloat() * 360F, 0.0F); - if (!entityliving.b()) { - continue; - } - a.a(((Entity) (entityliving))); - for (int k = 0; k < 20; k++) { - double d1 = (double) b + 0.5D + ((double) a.l.nextFloat() - 0.5D) * 2D; - double d3 = (double) c + 0.5D + ((double) a.l.nextFloat() - 0.5D) * 2D; - double d5 = (double) this.d + 0.5D + ((double) a.l.nextFloat() - 0.5D) * 2D; - - a.a("smoke", d1, d3, d5, 0.0D, 0.0D, 0.0D); - a.a("flame", d1, d3, d5, 0.0D, 0.0D, 0.0D); + if (this.e > 0) { + --this.e; + } else { + byte b0 = 4; + + for (int i = 0; i < b0; ++i) { + EntityLiving entityliving = (EntityLiving) ((EntityLiving) EntityTypes.a(this.h, this.a)); + + if (entityliving == null) { + return; + } + + int j = this.a.a(entityliving.getClass(), AxisAlignedBB.b((double) this.b, (double) this.c, (double) this.d, (double) (this.b + 1), (double) (this.c + 1), (double) (this.d + 1)).b(8.0D, 4.0D, 8.0D)).size(); + + if (j >= 6) { + this.b(); + return; + } + + if (entityliving != null) { + double d3 = (double) this.b + (this.a.l.nextDouble() - this.a.l.nextDouble()) * 4.0D; + double d4 = (double) (this.c + this.a.l.nextInt(3) - 1); + double d5 = (double) this.d + (this.a.l.nextDouble() - this.a.l.nextDouble()) * 4.0D; + + entityliving.c(d3, d4, d5, this.a.l.nextFloat() * 360.0F, 0.0F); + if (entityliving.b()) { + this.a.a((Entity) entityliving); + + for (int k = 0; k < 20; ++k) { + d0 = (double) this.b + 0.5D + ((double) this.a.l.nextFloat() - 0.5D) * 2.0D; + d1 = (double) this.c + 0.5D + ((double) this.a.l.nextFloat() - 0.5D) * 2.0D; + d2 = (double) this.d + 0.5D + ((double) this.a.l.nextFloat() - 0.5D) * 2.0D; + this.a.a("smoke", d0, d1, d2, 0.0D, 0.0D, 0.0D); + this.a.a("flame", d0, d1, d2, 0.0D, 0.0D, 0.0D); + } + + entityliving.R(); + this.b(); + } + } + } + + super.f(); } - - entityliving.R(); - b(); } - - super.f(); } private void b() { - e = 200 + a.l.nextInt(600); + this.e = 200 + this.a.l.nextInt(600); } public void a(NBTTagCompound nbttagcompound) { super.a(nbttagcompound); - h = nbttagcompound.h("EntityId"); - e = ((short) (nbttagcompound.c("Delay"))); + this.h = nbttagcompound.h("EntityId"); + this.e = nbttagcompound.c("Delay"); } public void b(NBTTagCompound nbttagcompound) { super.b(nbttagcompound); - nbttagcompound.a("EntityId", h); - nbttagcompound.a("Delay", (short) e); + nbttagcompound.a("EntityId", this.h); + nbttagcompound.a("Delay", (short) this.e); } } |