diff options
author | mbax <matt@phozop.net> | 2013-11-04 07:07:38 -0600 |
---|---|---|
committer | Wesley Wolfe <weswolf@aol.com> | 2013-11-30 19:26:12 -0600 |
commit | 2726696652179a5ead7dc07dd39edf7dfda687f7 (patch) | |
tree | ff78e22fdd4fc01889a5f6cc482b599f965cd93a /src/main/java/net/minecraft/server/EntityZombie.java | |
parent | ff8b70fbb7a96b9d2ff078afcf3b3ff90f200981 (diff) | |
download | craftbukkit-2726696652179a5ead7dc07dd39edf7dfda687f7.tar craftbukkit-2726696652179a5ead7dc07dd39edf7dfda687f7.tar.gz craftbukkit-2726696652179a5ead7dc07dd39edf7dfda687f7.tar.lz craftbukkit-2726696652179a5ead7dc07dd39edf7dfda687f7.tar.xz craftbukkit-2726696652179a5ead7dc07dd39edf7dfda687f7.zip |
Update CraftBukkit to Minecraft 1.7.2
Diffstat (limited to 'src/main/java/net/minecraft/server/EntityZombie.java')
-rw-r--r-- | src/main/java/net/minecraft/server/EntityZombie.java | 211 |
1 files changed, 136 insertions, 75 deletions
diff --git a/src/main/java/net/minecraft/server/EntityZombie.java b/src/main/java/net/minecraft/server/EntityZombie.java index 1aa684f5..6c6e03ed 100644 --- a/src/main/java/net/minecraft/server/EntityZombie.java +++ b/src/main/java/net/minecraft/server/EntityZombie.java @@ -14,43 +14,47 @@ public class EntityZombie extends EntityMonster { protected static final IAttribute bp = (new AttributeRanged("zombie.spawnReinforcements", 0.0D, 0.0D, 1.0D)).a("Spawn Reinforcements Chance"); private static final UUID bq = UUID.fromString("B9766B59-9566-4402-BC1F-2EE2A276D836"); private static final AttributeModifier br = new AttributeModifier(bq, "Baby speed boost", 0.5D, 1); - private int bs; + private final PathfinderGoalBreakDoor bs = new PathfinderGoalBreakDoor(this); + private int bt; + private boolean bu = false; + private float bv = -1.0F; + private float bw; private int lastTick = MinecraftServer.currentTick; // CraftBukkit public EntityZombie(World world) { super(world); this.getNavigation().b(true); this.goalSelector.a(0, new PathfinderGoalFloat(this)); - this.goalSelector.a(1, new PathfinderGoalBreakDoor(this)); this.goalSelector.a(2, new PathfinderGoalMeleeAttack(this, EntityHuman.class, 1.0D, false)); - this.goalSelector.a(3, new PathfinderGoalMeleeAttack(this, EntityVillager.class, 1.0D, true)); - this.goalSelector.a(4, new PathfinderGoalMoveTowardsRestriction(this, 1.0D)); - this.goalSelector.a(5, new PathfinderGoalMoveThroughVillage(this, 1.0D, false)); - this.goalSelector.a(6, new PathfinderGoalRandomStroll(this, 1.0D)); - this.goalSelector.a(7, new PathfinderGoalLookAtPlayer(this, EntityHuman.class, 8.0F)); - this.goalSelector.a(7, new PathfinderGoalRandomLookaround(this)); + this.goalSelector.a(4, new PathfinderGoalMeleeAttack(this, EntityVillager.class, 1.0D, true)); + this.goalSelector.a(5, new PathfinderGoalMoveTowardsRestriction(this, 1.0D)); + this.goalSelector.a(6, new PathfinderGoalMoveThroughVillage(this, 1.0D, false)); + this.goalSelector.a(7, new PathfinderGoalRandomStroll(this, 1.0D)); + this.goalSelector.a(8, new PathfinderGoalLookAtPlayer(this, EntityHuman.class, 8.0F)); + this.goalSelector.a(8, new PathfinderGoalRandomLookaround(this)); this.targetSelector.a(1, new PathfinderGoalHurtByTarget(this, true)); this.targetSelector.a(2, new PathfinderGoalNearestAttackableTarget(this, EntityHuman.class, 0, true)); this.targetSelector.a(2, new PathfinderGoalNearestAttackableTarget(this, EntityVillager.class, 0, false)); + this.a(0.6F, 1.8F); } - protected void az() { - super.az(); + protected void aD() { + super.aD(); this.getAttributeInstance(GenericAttributes.b).setValue(40.0D); this.getAttributeInstance(GenericAttributes.d).setValue(0.23000000417232513D); this.getAttributeInstance(GenericAttributes.e).setValue(3.0D); - this.aX().b(bp).setValue(this.random.nextDouble() * 0.10000000149011612D); + this.bc().b(bp).setValue(this.random.nextDouble() * 0.10000000149011612D); } - protected void a() { - super.a(); + protected void c() { + super.c(); this.getDataWatcher().a(12, Byte.valueOf((byte) 0)); this.getDataWatcher().a(13, Byte.valueOf((byte) 0)); this.getDataWatcher().a(14, Byte.valueOf((byte) 0)); } - public int aQ() { - int i = super.aQ() + 2; + public int aV() { + int i = super.aV() + 2; if (i > 20) { i = 20; @@ -59,14 +63,37 @@ public class EntityZombie extends EntityMonster { return i; } - protected boolean bf() { + protected boolean bk() { return true; } + public boolean bX() { + return this.bu; + } + + public void a(boolean flag) { + if (this.bu != flag) { + this.bu = flag; + if (flag) { + this.goalSelector.a(1, this.bs); + } else { + this.goalSelector.a((PathfinderGoal) this.bs); + } + } + } + public boolean isBaby() { return this.getDataWatcher().getByte(12) == 1; } + protected int getExpValue(EntityHuman entityhuman) { + if (this.isBaby()) { + this.b = (int) ((float) this.b * 2.5F); + } + + return super.getExpValue(entityhuman); + } + public void setBaby(boolean flag) { this.getDataWatcher().watch(12, Byte.valueOf((byte) (flag ? 1 : 0))); if (this.world != null && !this.world.isStatic) { @@ -77,6 +104,8 @@ public class EntityZombie extends EntityMonster { attributeinstance.a(br); } } + + this.k(flag); } public boolean isVillager() { @@ -87,11 +116,11 @@ public class EntityZombie extends EntityMonster { this.getDataWatcher().watch(13, Byte.valueOf((byte) (flag ? 1 : 0))); } - public void c() { + public void e() { if (this.world.v() && !this.world.isStatic && !this.isBaby()) { float f = this.d(1.0F); - if (f > 0.5F && this.random.nextFloat() * 30.0F < (f - 0.4F) * 2.0F && this.world.l(MathHelper.floor(this.locX), MathHelper.floor(this.locY), MathHelper.floor(this.locZ))) { + if (f > 0.5F && this.random.nextFloat() * 30.0F < (f - 0.4F) * 2.0F && this.world.i(MathHelper.floor(this.locX), MathHelper.floor(this.locY), MathHelper.floor(this.locZ))) { boolean flag = true; ItemStack itemstack = this.getEquipment(4); @@ -120,7 +149,7 @@ public class EntityZombie extends EntityMonster { } } - super.c(); + super.e(); } public boolean damageEntity(DamageSource damagesource, float f) { @@ -129,15 +158,15 @@ public class EntityZombie extends EntityMonster { } else { EntityLiving entityliving = this.getGoalTarget(); - if (entityliving == null && this.bN() instanceof EntityLiving) { - entityliving = (EntityLiving) this.bN(); + if (entityliving == null && this.bR() instanceof EntityLiving) { + entityliving = (EntityLiving) this.bR(); } if (entityliving == null && damagesource.getEntity() instanceof EntityLiving) { entityliving = (EntityLiving) damagesource.getEntity(); } - if (entityliving != null && this.world.difficulty >= 3 && (double) this.random.nextFloat() < this.getAttributeInstance(bp).getValue()) { + if (entityliving != null && this.world.difficulty == EnumDifficulty.HARD && (double) this.random.nextFloat() < this.getAttributeInstance(bp).getValue()) { int i = MathHelper.floor(this.locX); int j = MathHelper.floor(this.locY); int k = MathHelper.floor(this.locZ); @@ -148,10 +177,10 @@ public class EntityZombie extends EntityMonster { int j1 = j + MathHelper.nextInt(this.random, 7, 40) * MathHelper.nextInt(this.random, -1, 1); int k1 = k + MathHelper.nextInt(this.random, 7, 40) * MathHelper.nextInt(this.random, -1, 1); - if (this.world.w(i1, j1 - 1, k1) && this.world.getLightLevel(i1, j1, k1) < 10) { + if (World.a((IBlockAccess) this.world, i1, j1 - 1, k1) && this.world.getLightLevel(i1, j1, k1) < 10) { entityzombie.setPosition((double) i1, (double) j1, (double) k1); if (this.world.b(entityzombie.boundingBox) && this.world.getCubes(entityzombie, entityzombie.boundingBox).isEmpty() && !this.world.containsLiquid(entityzombie.boundingBox)) { - this.world.addEntity(entityzombie, org.bukkit.event.entity.CreatureSpawnEvent.SpawnReason.REINFORCEMENTS); + this.world.addEntity(entityzombie, org.bukkit.event.entity.CreatureSpawnEvent.SpawnReason.REINFORCEMENTS); // CraftBukkit entityzombie.setGoalTarget(entityliving); entityzombie.a((GroupDataEntity) null); this.getAttributeInstance(bp).a(new AttributeModifier("Zombie reinforcement caller charge", -0.05000000074505806D, 0)); @@ -166,9 +195,9 @@ public class EntityZombie extends EntityMonster { } } - public void l_() { - if (!this.world.isStatic && this.bV()) { - int i = this.bX(); + public void h() { + if (!this.world.isStatic && this.ca()) { + int i = this.cc(); // CraftBukkit start - Use wall time instead of ticks for villager conversion int elapsedTicks = MinecraftServer.currentTick - this.lastTick; @@ -176,50 +205,54 @@ public class EntityZombie extends EntityMonster { i *= elapsedTicks; // CraftBukkit end - this.bs -= i; - if (this.bs <= 0) { - this.bW(); + this.bt -= i; + if (this.bt <= 0) { + this.cb(); } } - super.l_(); + super.h(); } public boolean m(Entity entity) { boolean flag = super.m(entity); - if (flag && this.aZ() == null && this.isBurning() && this.random.nextFloat() < (float) this.world.difficulty * 0.3F) { - // CraftBukkit start - EntityCombustByEntityEvent event = new EntityCombustByEntityEvent(this.getBukkitEntity(), entity.getBukkitEntity(), 2 * this.world.difficulty); - this.world.getServer().getPluginManager().callEvent(event); + if (flag) { + int i = this.world.difficulty.a(); - if (!event.isCancelled()) { - entity.setOnFire(event.getDuration()); + if (this.be() == null && this.isBurning() && this.random.nextFloat() < (float) i * 0.3F) { + // CraftBukkit start + EntityCombustByEntityEvent event = new EntityCombustByEntityEvent(this.getBukkitEntity(), entity.getBukkitEntity(), 2 * i); + this.world.getServer().getPluginManager().callEvent(event); + + if (!event.isCancelled()) { + entity.setOnFire(event.getDuration()); + } + // CraftBukkit end } - // CraftBukkit end } return flag; } - protected String r() { + protected String t() { return "mob.zombie.say"; } - protected String aO() { + protected String aT() { return "mob.zombie.hurt"; } - protected String aP() { + protected String aU() { return "mob.zombie.death"; } - protected void a(int i, int j, int k, int l) { + protected void a(int i, int j, int k, Block block) { this.makeSound("mob.zombie.step", 0.15F, 1.0F); } - protected int getLootId() { - return Item.ROTTEN_FLESH.id; + protected Item getLoot() { + return Items.ROTTEN_FLESH; } public EnumMonsterType getMonsterType() { @@ -227,29 +260,29 @@ public class EntityZombie extends EntityMonster { } // CraftBukkit start - Return rare dropped item instead of dropping it - protected ItemStack l(int i) { + protected ItemStack getRareDrop(int i) { switch (this.random.nextInt(3)) { case 0: - return new ItemStack(Item.IRON_INGOT.id, 1, 0); + return new ItemStack(Items.IRON_INGOT, 1, 0); case 1: - return new ItemStack(Item.CARROT.id, 1, 0); + return new ItemStack(Items.CARROT, 1, 0); case 2: - return new ItemStack(Item.POTATO.id, 1, 0); + return new ItemStack(Items.POTATO, 1, 0); default: return null; } } // CraftBukkit end - protected void bw() { - super.bw(); - if (this.random.nextFloat() < (this.world.difficulty == 3 ? 0.05F : 0.01F)) { + protected void bA() { + super.bA(); + if (this.random.nextFloat() < (this.world.difficulty == EnumDifficulty.HARD ? 0.05F : 0.01F)) { int i = this.random.nextInt(3); if (i == 0) { - this.setEquipment(0, new ItemStack(Item.IRON_SWORD)); + this.setEquipment(0, new ItemStack(Items.IRON_SWORD)); } else { - this.setEquipment(0, new ItemStack(Item.IRON_SPADE)); + this.setEquipment(0, new ItemStack(Items.IRON_SPADE)); } } } @@ -264,7 +297,8 @@ public class EntityZombie extends EntityMonster { nbttagcompound.setBoolean("IsVillager", true); } - nbttagcompound.setInt("ConversionTime", this.bV() ? this.bs : -1); + nbttagcompound.setInt("ConversionTime", this.ca() ? this.bt : -1); + nbttagcompound.setBoolean("CanBreakDoors", this.bX()); } public void a(NBTTagCompound nbttagcompound) { @@ -277,15 +311,17 @@ public class EntityZombie extends EntityMonster { this.setVillager(true); } - if (nbttagcompound.hasKey("ConversionTime") && nbttagcompound.getInt("ConversionTime") > -1) { + if (nbttagcompound.hasKeyOfType("ConversionTime", 99) && nbttagcompound.getInt("ConversionTime") > -1) { this.a(nbttagcompound.getInt("ConversionTime")); } + + this.a(nbttagcompound.getBoolean("CanBreakDoors")); } public void a(EntityLiving entityliving) { super.a(entityliving); - if (this.world.difficulty >= 2 && entityliving instanceof EntityVillager) { - if (this.world.difficulty == 2 && this.random.nextBoolean()) { + if ((this.world.difficulty == EnumDifficulty.NORMAL || this.world.difficulty == EnumDifficulty.HARD) && entityliving instanceof EntityVillager) { + if (this.random.nextBoolean()) { return; } @@ -310,7 +346,7 @@ public class EntityZombie extends EntityMonster { this.h(this.random.nextFloat() < 0.55F * f); if (object == null) { - object = new GroupDataZombie(this, this.world.random.nextFloat() < 0.05F, this.world.random.nextFloat() < 0.05F, (EmptyClass4) null); + object = new GroupDataZombie(this, this.world.random.nextFloat() < 0.05F, this.world.random.nextFloat() < 0.05F, (EmptyClassZombie) null); } if (object instanceof GroupDataZombie) { @@ -325,31 +361,38 @@ public class EntityZombie extends EntityMonster { } } - this.bw(); - this.bx(); + this.a(this.random.nextFloat() < f * 0.1F); + this.bA(); + this.bB(); if (this.getEquipment(4) == null) { - Calendar calendar = this.world.W(); + Calendar calendar = this.world.V(); if (calendar.get(2) + 1 == 10 && calendar.get(5) == 31 && this.random.nextFloat() < 0.25F) { - this.setEquipment(4, new ItemStack(this.random.nextFloat() < 0.1F ? Block.JACK_O_LANTERN : Block.PUMPKIN)); + this.setEquipment(4, new ItemStack(this.random.nextFloat() < 0.1F ? Blocks.JACK_O_LANTERN : Blocks.PUMPKIN)); this.dropChances[4] = 0.0F; } } this.getAttributeInstance(GenericAttributes.c).a(new AttributeModifier("Random spawn bonus", this.random.nextDouble() * 0.05000000074505806D, 0)); - this.getAttributeInstance(GenericAttributes.b).a(new AttributeModifier("Random zombie-spawn bonus", this.random.nextDouble() * 1.5D, 2)); + double d0 = this.random.nextDouble() * 1.5D * (double) this.world.b(this.locX, this.locY, this.locZ); + + if (d0 > 1.0D) { + this.getAttributeInstance(GenericAttributes.b).a(new AttributeModifier("Random zombie-spawn bonus", d0, 2)); + } + if (this.random.nextFloat() < f * 0.05F) { this.getAttributeInstance(bp).a(new AttributeModifier("Leader zombie bonus", this.random.nextDouble() * 0.25D + 0.5D, 0)); this.getAttributeInstance(GenericAttributes.a).a(new AttributeModifier("Leader zombie bonus", this.random.nextDouble() * 3.0D + 1.0D, 2)); + this.a(true); } return (GroupDataEntity) object; } public boolean a(EntityHuman entityhuman) { - ItemStack itemstack = entityhuman.by(); + ItemStack itemstack = entityhuman.bD(); - if (itemstack != null && itemstack.getItem() == Item.GOLDEN_APPLE && itemstack.getData() == 0 && this.isVillager() && this.hasEffect(MobEffectList.WEAKNESS)) { + if (itemstack != null && itemstack.getItem() == Items.GOLDEN_APPLE && itemstack.getData() == 0 && this.isVillager() && this.hasEffect(MobEffectList.WEAKNESS)) { if (!entityhuman.abilities.canInstantlyBuild) { --itemstack.count; } @@ -369,27 +412,27 @@ public class EntityZombie extends EntityMonster { } protected void a(int i) { - this.bs = i; + this.bt = i; this.getDataWatcher().watch(14, Byte.valueOf((byte) 1)); - this.k(MobEffectList.WEAKNESS.id); - this.addEffect(new MobEffect(MobEffectList.INCREASE_DAMAGE.id, i, Math.min(this.world.difficulty - 1, 0))); + this.m(MobEffectList.WEAKNESS.id); + this.addEffect(new MobEffect(MobEffectList.INCREASE_DAMAGE.id, i, Math.min(this.world.difficulty.a() - 1, 0))); this.world.broadcastEntityEffect(this, (byte) 16); } protected boolean isTypeNotPersistent() { - return !this.bV(); + return !this.ca(); } - public boolean bV() { + public boolean ca() { return this.getDataWatcher().getByte(14) == 1; } - protected void bW() { + protected void cb() { EntityVillager entityvillager = new EntityVillager(this.world); entityvillager.j(this); entityvillager.a((GroupDataEntity) null); - entityvillager.bX(); + entityvillager.cb(); if (this.isBaby()) { entityvillager.setAge(-24000); } @@ -400,7 +443,7 @@ public class EntityZombie extends EntityMonster { this.world.a((EntityHuman) null, 1017, (int) this.locX, (int) this.locY, (int) this.locZ, 0); } - protected int bX() { + protected int cc() { int i = 1; if (this.random.nextFloat() < 0.01F) { @@ -409,9 +452,9 @@ public class EntityZombie extends EntityMonster { for (int k = (int) this.locX - 4; k < (int) this.locX + 4 && j < 14; ++k) { for (int l = (int) this.locY - 4; l < (int) this.locY + 4 && j < 14; ++l) { for (int i1 = (int) this.locZ - 4; i1 < (int) this.locZ + 4 && j < 14; ++i1) { - int j1 = this.world.getTypeId(k, l, i1); + Block block = this.world.getType(k, l, i1); - if (j1 == Block.IRON_FENCE.id || j1 == Block.BED.id) { + if (block == Blocks.IRON_FENCE || block == Blocks.BED) { if (this.random.nextFloat() < 0.3F) { ++i; } @@ -425,4 +468,22 @@ public class EntityZombie extends EntityMonster { return i; } + + public void k(boolean flag) { + this.a(flag ? 0.5F : 1.0F); + } + + protected final void a(float f, float f1) { + boolean flag = this.bv > 0.0F && this.bw > 0.0F; + + this.bv = f; + this.bw = f1; + if (!flag) { + this.a(1.0F); + } + } + + protected final void a(float f) { + super.a(this.bv * f, this.bw * f); + } } |