summaryrefslogtreecommitdiffstats
path: root/src/main/java/net/minecraft/server/EntityPotion.java
diff options
context:
space:
mode:
authorAndrew Ardill <andrew.ardill@gmail.com>2011-11-29 21:22:35 +1100
committerAndrew Ardill <andrew.ardill@gmail.com>2011-11-29 21:22:35 +1100
commit2759809ecba4e5f2d8c8ae51f5781a0c1a96b0c1 (patch)
tree28525ae33fee47b70b749e0f22b4fef588846399 /src/main/java/net/minecraft/server/EntityPotion.java
parenta51eb9c3cac28dce1d4443e35f78460695ea97d4 (diff)
downloadcraftbukkit-2759809ecba4e5f2d8c8ae51f5781a0c1a96b0c1.tar
craftbukkit-2759809ecba4e5f2d8c8ae51f5781a0c1a96b0c1.tar.gz
craftbukkit-2759809ecba4e5f2d8c8ae51f5781a0c1a96b0c1.tar.lz
craftbukkit-2759809ecba4e5f2d8c8ae51f5781a0c1a96b0c1.tar.xz
craftbukkit-2759809ecba4e5f2d8c8ae51f5781a0c1a96b0c1.zip
Fix Craft Entity constructors and toStrings.
Also, standardise getHandle and clean up in general. getHandle is now using the 'entity' member variable instead of super.getHandle, as this reduces the number of chained calls needed.
Diffstat (limited to 'src/main/java/net/minecraft/server/EntityPotion.java')
-rw-r--r--src/main/java/net/minecraft/server/EntityPotion.java87
1 files changed, 87 insertions, 0 deletions
diff --git a/src/main/java/net/minecraft/server/EntityPotion.java b/src/main/java/net/minecraft/server/EntityPotion.java
new file mode 100644
index 00000000..41247f51
--- /dev/null
+++ b/src/main/java/net/minecraft/server/EntityPotion.java
@@ -0,0 +1,87 @@
+package net.minecraft.server;
+
+import java.util.Iterator;
+import java.util.List;
+
+public class EntityPotion extends EntityProjectile {
+
+ private int d;
+
+ public EntityPotion(World world) {
+ super(world);
+ }
+
+ public EntityPotion(World world, EntityLiving entityliving, int i) {
+ super(world, entityliving);
+ this.d = i;
+ }
+
+ public EntityPotion(World world, double d0, double d1, double d2, int i) {
+ super(world, d0, d1, d2);
+ this.d = i;
+ }
+
+ protected float e() {
+ return 0.05F;
+ }
+
+ protected float c() {
+ return 0.5F;
+ }
+
+ protected float d() {
+ return -20.0F;
+ }
+
+ public int f() {
+ return this.d;
+ }
+
+ protected void a(MovingObjectPosition movingobjectposition) {
+ if (!this.world.isStatic) {
+ List list = Item.POTION.b(this.d);
+
+ if (list != null && !list.isEmpty()) {
+ AxisAlignedBB axisalignedbb = this.boundingBox.b(4.0D, 2.0D, 4.0D);
+ List list1 = this.world.a(EntityLiving.class, axisalignedbb);
+
+ if (list1 != null && !list1.isEmpty()) {
+ Iterator iterator = list1.iterator();
+
+ while (iterator.hasNext()) {
+ Entity entity = (Entity) iterator.next();
+ double d0 = this.i(entity);
+
+ if (d0 < 16.0D) {
+ double d1 = 1.0D - Math.sqrt(d0) / 4.0D;
+
+ if (entity == movingobjectposition.entity) {
+ d1 = 1.0D;
+ }
+
+ Iterator iterator1 = list.iterator();
+
+ while (iterator1.hasNext()) {
+ MobEffect mobeffect = (MobEffect) iterator1.next();
+ int i = mobeffect.getEffectId();
+
+ if (MobEffectList.byId[i].b()) {
+ MobEffectList.byId[i].a(this.shooter, (EntityLiving) entity, mobeffect.getAmplifier(), d1);
+ } else {
+ int j = (int) (d1 * (double) mobeffect.getDuration() + 0.5D);
+
+ if (j > 20) {
+ ((EntityLiving) entity).addEffect(new MobEffect(i, j, mobeffect.getAmplifier()));
+ }
+ }
+ }
+ }
+ }
+ }
+ }
+
+ this.world.f(2002, (int) Math.round(this.locX), (int) Math.round(this.locY), (int) Math.round(this.locZ), this.d);
+ this.die();
+ }
+ }
+}