summaryrefslogtreecommitdiffstats
path: root/src/main/java/net/minecraft/server/EntitySkeleton.java
diff options
context:
space:
mode:
authorThinkofdeath <thinkofdeath@spigotmc.org>2014-11-26 08:32:16 +1100
committermd_5 <git@md-5.net>2014-11-28 17:16:30 +1100
commit24557bc2b37deb6a0edf497d547471832457b1dd (patch)
treec560572889a3b0b34964a0cddb35dc87fda3c914 /src/main/java/net/minecraft/server/EntitySkeleton.java
parenta4805dbd77da057cc1ea0bf344379bc6e53ca1f6 (diff)
downloadcraftbukkit-24557bc2b37deb6a0edf497d547471832457b1dd.tar
craftbukkit-24557bc2b37deb6a0edf497d547471832457b1dd.tar.gz
craftbukkit-24557bc2b37deb6a0edf497d547471832457b1dd.tar.lz
craftbukkit-24557bc2b37deb6a0edf497d547471832457b1dd.tar.xz
craftbukkit-24557bc2b37deb6a0edf497d547471832457b1dd.zip
Update to Minecraft 1.8
For more information please see http://www.spigotmc.org/
Diffstat (limited to 'src/main/java/net/minecraft/server/EntitySkeleton.java')
-rw-r--r--src/main/java/net/minecraft/server/EntitySkeleton.java294
1 files changed, 0 insertions, 294 deletions
diff --git a/src/main/java/net/minecraft/server/EntitySkeleton.java b/src/main/java/net/minecraft/server/EntitySkeleton.java
deleted file mode 100644
index 479936f3..00000000
--- a/src/main/java/net/minecraft/server/EntitySkeleton.java
+++ /dev/null
@@ -1,294 +0,0 @@
-package net.minecraft.server;
-
-import java.util.Calendar;
-
-import org.bukkit.event.entity.EntityCombustEvent; // CraftBukkit
-
-public class EntitySkeleton extends EntityMonster implements IRangedEntity {
-
- private PathfinderGoalArrowAttack bp = new PathfinderGoalArrowAttack(this, 1.0D, 20, 60, 15.0F);
- private PathfinderGoalMeleeAttack bq = new PathfinderGoalMeleeAttack(this, EntityHuman.class, 1.2D, false);
-
- public EntitySkeleton(World world) {
- super(world);
- this.goalSelector.a(1, new PathfinderGoalFloat(this));
- this.goalSelector.a(2, new PathfinderGoalRestrictSun(this));
- this.goalSelector.a(3, new PathfinderGoalFleeSun(this, 1.0D));
- this.goalSelector.a(5, new PathfinderGoalRandomStroll(this, 1.0D));
- this.goalSelector.a(6, new PathfinderGoalLookAtPlayer(this, EntityHuman.class, 8.0F));
- this.goalSelector.a(6, new PathfinderGoalRandomLookaround(this));
- this.targetSelector.a(1, new PathfinderGoalHurtByTarget(this, false));
- this.targetSelector.a(2, new PathfinderGoalNearestAttackableTarget(this, EntityHuman.class, 0, true));
- if (world != null && !world.isStatic) {
- this.bZ();
- }
- }
-
- protected void aD() {
- super.aD();
- this.getAttributeInstance(GenericAttributes.d).setValue(0.25D);
- }
-
- protected void c() {
- super.c();
- this.datawatcher.a(13, new Byte((byte) 0));
- }
-
- public boolean bk() {
- return true;
- }
-
- protected String t() {
- return "mob.skeleton.say";
- }
-
- protected String aT() {
- return "mob.skeleton.hurt";
- }
-
- protected String aU() {
- return "mob.skeleton.death";
- }
-
- protected void a(int i, int j, int k, Block block) {
- this.makeSound("mob.skeleton.step", 0.15F, 1.0F);
- }
-
- public boolean n(Entity entity) {
- if (super.n(entity)) {
- if (this.getSkeletonType() == 1 && entity instanceof EntityLiving) {
- ((EntityLiving) entity).addEffect(new MobEffect(MobEffectList.WITHER.id, 200));
- }
-
- return true;
- } else {
- return false;
- }
- }
-
- public EnumMonsterType getMonsterType() {
- return EnumMonsterType.UNDEAD;
- }
-
- public void e() {
- if (this.world.w() && !this.world.isStatic) {
- float f = this.d(1.0F);
-
- 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);
-
- if (itemstack != null) {
- if (itemstack.g()) {
- itemstack.setData(itemstack.j() + this.random.nextInt(2));
- if (itemstack.j() >= itemstack.l()) {
- this.a(itemstack);
- this.setEquipment(4, (ItemStack) null);
- }
- }
-
- flag = false;
- }
-
- if (flag) {
- // CraftBukkit start
- EntityCombustEvent event = new EntityCombustEvent(this.getBukkitEntity(), 8);
- this.world.getServer().getPluginManager().callEvent(event);
-
- if (!event.isCancelled()) {
- this.setOnFire(event.getDuration());
- }
- // CraftBukkit end
- }
- }
- }
-
- if (this.world.isStatic && this.getSkeletonType() == 1) {
- this.a(0.72F, 2.34F);
- }
-
- super.e();
- }
-
- public void ab() {
- super.ab();
- if (this.vehicle instanceof EntityCreature) {
- EntityCreature entitycreature = (EntityCreature) this.vehicle;
-
- this.aM = entitycreature.aM;
- }
- }
-
- public void die(DamageSource damagesource) {
- super.die(damagesource);
- if (damagesource.i() instanceof EntityArrow && damagesource.getEntity() instanceof EntityHuman) {
- EntityHuman entityhuman = (EntityHuman) damagesource.getEntity();
- double d0 = entityhuman.locX - this.locX;
- double d1 = entityhuman.locZ - this.locZ;
-
- if (d0 * d0 + d1 * d1 >= 2500.0D) {
- entityhuman.a((Statistic) AchievementList.v);
- }
- }
- }
-
- protected Item getLoot() {
- return Items.ARROW;
- }
-
- protected void dropDeathLoot(boolean flag, int i) {
- int j;
- int k;
-
- if (this.getSkeletonType() == 1) {
- j = this.random.nextInt(3 + i) - 1;
-
- for (k = 0; k < j; ++k) {
- this.a(Items.COAL, 1);
- }
- } else {
- j = this.random.nextInt(3 + i);
-
- for (k = 0; k < j; ++k) {
- this.a(Items.ARROW, 1);
- }
- }
-
- j = this.random.nextInt(3 + i);
-
- for (k = 0; k < j; ++k) {
- this.a(Items.BONE, 1);
- }
- }
-
- protected void getRareDrop(int i) {
- if (this.getSkeletonType() == 1) {
- this.a(new ItemStack(Items.SKULL, 1, 1), 0.0F);
- }
- }
-
- protected void bC() {
- super.bC();
- this.setEquipment(0, new ItemStack(Items.BOW));
- }
-
- public GroupDataEntity prepare(GroupDataEntity groupdataentity) {
- groupdataentity = super.prepare(groupdataentity);
- if (this.world.worldProvider instanceof WorldProviderHell && this.aI().nextInt(5) > 0) {
- this.goalSelector.a(4, this.bq);
- this.setSkeletonType(1);
- this.setEquipment(0, new ItemStack(Items.STONE_SWORD));
- this.getAttributeInstance(GenericAttributes.e).setValue(4.0D);
- } else {
- this.goalSelector.a(4, this.bp);
- this.bC();
- this.bD();
- }
-
- this.h(this.random.nextFloat() < 0.55F * this.world.b(this.locX, this.locY, this.locZ));
- if (this.getEquipment(4) == null) {
- 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 ? Blocks.JACK_O_LANTERN : Blocks.PUMPKIN));
- this.dropChances[4] = 0.0F;
- }
- }
-
- return groupdataentity;
- }
-
- public void bZ() {
- this.goalSelector.a((PathfinderGoal) this.bq);
- this.goalSelector.a((PathfinderGoal) this.bp);
- ItemStack itemstack = this.be();
-
- if (itemstack != null && itemstack.getItem() == Items.BOW) {
- this.goalSelector.a(4, this.bp);
- } else {
- this.goalSelector.a(4, this.bq);
- }
- }
-
- public void a(EntityLiving entityliving, float f) {
- EntityArrow entityarrow = new EntityArrow(this.world, this, entityliving, 1.6F, (float) (14 - this.world.difficulty.a() * 4));
- int i = EnchantmentManager.getEnchantmentLevel(Enchantment.ARROW_DAMAGE.id, this.be());
- int j = EnchantmentManager.getEnchantmentLevel(Enchantment.ARROW_KNOCKBACK.id, this.be());
-
- entityarrow.b((double) (f * 2.0F) + this.random.nextGaussian() * 0.25D + (double) ((float) this.world.difficulty.a() * 0.11F));
- if (i > 0) {
- entityarrow.b(entityarrow.e() + (double) i * 0.5D + 0.5D);
- }
-
- if (j > 0) {
- entityarrow.setKnockbackStrength(j);
- }
-
- if (EnchantmentManager.getEnchantmentLevel(Enchantment.ARROW_FIRE.id, this.be()) > 0 || this.getSkeletonType() == 1) {
- // CraftBukkit start - call EntityCombustEvent
- EntityCombustEvent event = new EntityCombustEvent(entityarrow.getBukkitEntity(), 100);
- this.world.getServer().getPluginManager().callEvent(event);
-
- if (!event.isCancelled()) {
- entityarrow.setOnFire(event.getDuration());
- }
- // CraftBukkit end
- }
-
- // CraftBukkit start
- org.bukkit.event.entity.EntityShootBowEvent event = org.bukkit.craftbukkit.event.CraftEventFactory.callEntityShootBowEvent(this, this.be(), entityarrow, 0.8F);
- if (event.isCancelled()) {
- event.getProjectile().remove();
- return;
- }
-
- if (event.getProjectile() == entityarrow.getBukkitEntity()) {
- world.addEntity(entityarrow);
- }
- // CraftBukkit end
-
- this.makeSound("random.bow", 1.0F, 1.0F / (this.aI().nextFloat() * 0.4F + 0.8F));
- // this.world.addEntity(entityarrow); // CraftBukkit - moved up
- }
-
- public int getSkeletonType() {
- return this.datawatcher.getByte(13);
- }
-
- public void setSkeletonType(int i) {
- this.datawatcher.watch(13, Byte.valueOf((byte) i));
- this.fireProof = i == 1;
- if (i == 1) {
- this.a(0.72F, 2.34F);
- } else {
- this.a(0.6F, 1.8F);
- }
- }
-
- public void a(NBTTagCompound nbttagcompound) {
- super.a(nbttagcompound);
- if (nbttagcompound.hasKeyOfType("SkeletonType", 99)) {
- byte b0 = nbttagcompound.getByte("SkeletonType");
-
- this.setSkeletonType(b0);
- }
-
- this.bZ();
- }
-
- public void b(NBTTagCompound nbttagcompound) {
- super.b(nbttagcompound);
- nbttagcompound.setByte("SkeletonType", (byte) this.getSkeletonType());
- }
-
- public void setEquipment(int i, ItemStack itemstack) {
- super.setEquipment(i, itemstack);
- if (!this.world.isStatic && i == 0) {
- this.bZ();
- }
- }
-
- public double ad() {
- return super.ad() - 0.5D;
- }
-}