summaryrefslogtreecommitdiffstats
path: root/src
diff options
context:
space:
mode:
authorfeildmaster <admin@feildmaster.com>2012-03-26 13:55:35 -0500
committerWarren Loo <evilseph@gmail.com>2012-03-27 20:29:03 -0400
commitec123deb741dc999969eb48ab2dbdf36b23a9c81 (patch)
treebae5c81ae0d8282fe42996f6c526b9fa6c9d0d52 /src
parentc100e20d605a0dde2c2e149954324e1659a6108b (diff)
downloadcraftbukkit-ec123deb741dc999969eb48ab2dbdf36b23a9c81.tar
craftbukkit-ec123deb741dc999969eb48ab2dbdf36b23a9c81.tar.gz
craftbukkit-ec123deb741dc999969eb48ab2dbdf36b23a9c81.tar.lz
craftbukkit-ec123deb741dc999969eb48ab2dbdf36b23a9c81.tar.xz
craftbukkit-ec123deb741dc999969eb48ab2dbdf36b23a9c81.zip
Adding PathfinderGoalBreed for diff visibility.
Diffstat (limited to 'src')
-rw-r--r--src/main/java/net/minecraft/server/PathfinderGoalBreed.java91
1 files changed, 91 insertions, 0 deletions
diff --git a/src/main/java/net/minecraft/server/PathfinderGoalBreed.java b/src/main/java/net/minecraft/server/PathfinderGoalBreed.java
new file mode 100644
index 00000000..08f89fc8
--- /dev/null
+++ b/src/main/java/net/minecraft/server/PathfinderGoalBreed.java
@@ -0,0 +1,91 @@
+package net.minecraft.server;
+
+import java.util.Iterator;
+import java.util.List;
+import java.util.Random;
+
+public class PathfinderGoalBreed extends PathfinderGoal {
+
+ private EntityAnimal d;
+ World a;
+ private EntityAnimal e;
+ int b = 0;
+ float c;
+
+ public PathfinderGoalBreed(EntityAnimal entityanimal, float f) {
+ this.d = entityanimal;
+ this.a = entityanimal.world;
+ this.c = f;
+ this.a(3);
+ }
+
+ public boolean a() {
+ if (!this.d.r_()) {
+ return false;
+ } else {
+ this.e = this.f();
+ return this.e != null;
+ }
+ }
+
+ public boolean b() {
+ return this.e.isAlive() && this.e.r_() && this.b < 60;
+ }
+
+ public void d() {
+ this.e = null;
+ this.b = 0;
+ }
+
+ public void e() {
+ this.d.getControllerLook().a(this.e, 10.0F, (float) this.d.D());
+ this.d.al().a((EntityLiving) this.e, this.c);
+ ++this.b;
+ if (this.b == 60) {
+ this.i();
+ }
+ }
+
+ private EntityAnimal f() {
+ float f = 8.0F;
+ List list = this.a.a(this.d.getClass(), this.d.boundingBox.grow((double) f, (double) f, (double) f));
+ Iterator iterator = list.iterator();
+
+ EntityAnimal entityanimal;
+
+ do {
+ if (!iterator.hasNext()) {
+ return null;
+ }
+
+ Entity entity = (Entity) iterator.next();
+
+ entityanimal = (EntityAnimal) entity;
+ } while (!this.d.mate(entityanimal));
+
+ return entityanimal;
+ }
+
+ private void i() {
+ EntityAnimal entityanimal = this.d.createChild(this.e);
+
+ if (entityanimal != null) {
+ this.d.setAge(6000);
+ this.e.setAge(6000);
+ this.d.s_();
+ this.e.s_();
+ entityanimal.setAge(-24000);
+ entityanimal.setPositionRotation(this.d.locX, this.d.locY, this.d.locZ, 0.0F, 0.0F);
+ this.a.addEntity(entityanimal);
+ Random random = this.d.an();
+
+ for (int i = 0; i < 7; ++i) {
+ double d0 = random.nextGaussian() * 0.02D;
+ double d1 = random.nextGaussian() * 0.02D;
+ double d2 = random.nextGaussian() * 0.02D;
+
+ this.a.a("heart", this.d.locX + (double) (random.nextFloat() * this.d.width * 2.0F) - (double) this.d.width, this.d.locY + 0.5D + (double) (random.nextFloat() * this.d.length), this.d.locZ + (double) (random.nextFloat() * this.d.width * 2.0F) - (double) this.d.width, d0, d1, d2);
+ }
+ }
+ }
+}