summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorT00thpick1 <t00thpick1dirko@gmail.com>2013-07-19 10:55:29 -0400
committerNate Mortensen <nate.richard.mortensen@gmail.com>2013-08-06 13:03:13 -0600
commit485e9ad93f314837270a297270a19b3b9ccd02e4 (patch)
tree0c25a1836432303c21c2b6aa8253cc201de4bfdf
parent4aeb3ff63d31edd070ced439ffbae79d9a938492 (diff)
downloadcraftbukkit-485e9ad93f314837270a297270a19b3b9ccd02e4.tar
craftbukkit-485e9ad93f314837270a297270a19b3b9ccd02e4.tar.gz
craftbukkit-485e9ad93f314837270a297270a19b3b9ccd02e4.tar.lz
craftbukkit-485e9ad93f314837270a297270a19b3b9ccd02e4.tar.xz
craftbukkit-485e9ad93f314837270a297270a19b3b9ccd02e4.zip
Add PathfinderGoalMakeLove for diff visibility
-rw-r--r--src/main/java/net/minecraft/server/PathfinderGoalMakeLove.java90
1 files changed, 90 insertions, 0 deletions
diff --git a/src/main/java/net/minecraft/server/PathfinderGoalMakeLove.java b/src/main/java/net/minecraft/server/PathfinderGoalMakeLove.java
new file mode 100644
index 00000000..ffad05a5
--- /dev/null
+++ b/src/main/java/net/minecraft/server/PathfinderGoalMakeLove.java
@@ -0,0 +1,90 @@
+package net.minecraft.server;
+
+public class PathfinderGoalMakeLove extends PathfinderGoal {
+
+ private EntityVillager b;
+ private EntityVillager c;
+ private World d;
+ private int e;
+ Village a;
+
+ public PathfinderGoalMakeLove(EntityVillager entityvillager) {
+ this.b = entityvillager;
+ this.d = entityvillager.world;
+ this.a(3);
+ }
+
+ public boolean a() {
+ if (this.b.getAge() != 0) {
+ return false;
+ } else if (this.b.aC().nextInt(500) != 0) {
+ return false;
+ } else {
+ this.a = this.d.villages.getClosestVillage(MathHelper.floor(this.b.locX), MathHelper.floor(this.b.locY), MathHelper.floor(this.b.locZ), 0);
+ if (this.a == null) {
+ return false;
+ } else if (!this.f()) {
+ return false;
+ } else {
+ Entity entity = this.d.a(EntityVillager.class, this.b.boundingBox.grow(8.0D, 3.0D, 8.0D), (Entity) this.b);
+
+ if (entity == null) {
+ return false;
+ } else {
+ this.c = (EntityVillager) entity;
+ return this.c.getAge() == 0;
+ }
+ }
+ }
+ }
+
+ public void c() {
+ this.e = 300;
+ this.b.i(true);
+ }
+
+ public void d() {
+ this.a = null;
+ this.c = null;
+ this.b.i(false);
+ }
+
+ public boolean b() {
+ return this.e >= 0 && this.f() && this.b.getAge() == 0;
+ }
+
+ public void e() {
+ --this.e;
+ this.b.getControllerLook().a(this.c, 10.0F, 30.0F);
+ if (this.b.e(this.c) > 2.25D) {
+ this.b.getNavigation().a((Entity) this.c, 0.25D);
+ } else if (this.e == 0 && this.c.bU()) {
+ this.g();
+ }
+
+ if (this.b.aC().nextInt(35) == 0) {
+ this.d.broadcastEntityEffect(this.b, (byte) 12);
+ }
+ }
+
+ private boolean f() {
+ if (!this.a.i()) {
+ return false;
+ } else {
+ int i = (int) ((double) ((float) this.a.getDoorCount()) * 0.35D);
+
+ return this.a.getPopulationCount() < i;
+ }
+ }
+
+ private void g() {
+ EntityVillager entityvillager = this.b.b((EntityAgeable) this.c);
+
+ this.c.setAge(6000);
+ this.b.setAge(6000);
+ entityvillager.setAge(-24000);
+ entityvillager.setPositionRotation(this.b.locX, this.b.locY, this.b.locZ, 0.0F, 0.0F);
+ this.d.addEntity(entityvillager);
+ this.d.broadcastEntityEffect(entityvillager, (byte) 12);
+ }
+}