Upstream Paper

This commit is contained in:
Sotr
2019-03-04 18:16:32 +08:00
commit cadd3f71c0
1106 changed files with 193757 additions and 0 deletions

View File

@@ -0,0 +1,303 @@
package net.minecraft.server;
import java.util.Iterator;
import javax.annotation.Nullable;
public class AxisAlignedBB {
public final double minX; public double getMinX() { return this.minX; } // Paper - OBFHELPER
public final double minY; public double getMinY() { return this.minY; } // Paper - OBFHELPER
public final double minZ; public double getMinZ() { return this.minZ; } // Paper - OBFHELPER
public final double maxX; public double getMaxX() { return this.maxX; } // Paper - OBFHELPER
public final double maxY; public double getMaxY() { return this.maxY; } // Paper - OBFHELPER
public final double maxZ; public double getMaxZ() { return this.maxZ; } // Paper - OBFHELPER
public AxisAlignedBB(double d0, double d1, double d2, double d3, double d4, double d5) {
this.minX = Math.min(d0, d3);
this.minY = Math.min(d1, d4);
this.minZ = Math.min(d2, d5);
this.maxX = Math.max(d0, d3);
this.maxY = Math.max(d1, d4);
this.maxZ = Math.max(d2, d5);
}
public AxisAlignedBB(BlockPosition blockposition) {
this((double) blockposition.getX(), (double) blockposition.getY(), (double) blockposition.getZ(), (double) (blockposition.getX() + 1), (double) (blockposition.getY() + 1), (double) (blockposition.getZ() + 1));
}
public AxisAlignedBB(BlockPosition blockposition, BlockPosition blockposition1) {
this((double) blockposition.getX(), (double) blockposition.getY(), (double) blockposition.getZ(), (double) blockposition1.getX(), (double) blockposition1.getY(), (double) blockposition1.getZ());
}
public double a(EnumDirection.EnumAxis enumdirection_enumaxis) {
return enumdirection_enumaxis.a(this.minX, this.minY, this.minZ);
}
public double b(EnumDirection.EnumAxis enumdirection_enumaxis) {
return enumdirection_enumaxis.a(this.maxX, this.maxY, this.maxZ);
}
public boolean equals(Object object) {
if (this == object) {
return true;
} else if (!(object instanceof AxisAlignedBB)) {
return false;
} else {
AxisAlignedBB axisalignedbb = (AxisAlignedBB) object;
return Double.compare(axisalignedbb.minX, this.minX) != 0 ? false : (Double.compare(axisalignedbb.minY, this.minY) != 0 ? false : (Double.compare(axisalignedbb.minZ, this.minZ) != 0 ? false : (Double.compare(axisalignedbb.maxX, this.maxX) != 0 ? false : (Double.compare(axisalignedbb.maxY, this.maxY) != 0 ? false : Double.compare(axisalignedbb.maxZ, this.maxZ) == 0))));
}
}
public int hashCode() {
long i = Double.doubleToLongBits(this.minX);
int j = (int) (i ^ i >>> 32);
i = Double.doubleToLongBits(this.minY);
j = 31 * j + (int) (i ^ i >>> 32);
i = Double.doubleToLongBits(this.minZ);
j = 31 * j + (int) (i ^ i >>> 32);
i = Double.doubleToLongBits(this.maxX);
j = 31 * j + (int) (i ^ i >>> 32);
i = Double.doubleToLongBits(this.maxY);
j = 31 * j + (int) (i ^ i >>> 32);
i = Double.doubleToLongBits(this.maxZ);
j = 31 * j + (int) (i ^ i >>> 32);
return j;
}
public AxisAlignedBB a(double d0, double d1, double d2) {
double d3 = this.minX;
double d4 = this.minY;
double d5 = this.minZ;
double d6 = this.maxX;
double d7 = this.maxY;
double d8 = this.maxZ;
if (d0 < 0.0D) {
d3 -= d0;
} else if (d0 > 0.0D) {
d6 -= d0;
}
if (d1 < 0.0D) {
d4 -= d1;
} else if (d1 > 0.0D) {
d7 -= d1;
}
if (d2 < 0.0D) {
d5 -= d2;
} else if (d2 > 0.0D) {
d8 -= d2;
}
return new AxisAlignedBB(d3, d4, d5, d6, d7, d8);
}
public AxisAlignedBB expand(double x, double y, double z) { return b(x, y, z); } // Paper - OBFHELPER
public AxisAlignedBB b(double d0, double d1, double d2) {
double d3 = this.minX;
double d4 = this.minY;
double d5 = this.minZ;
double d6 = this.maxX;
double d7 = this.maxY;
double d8 = this.maxZ;
if (d0 < 0.0D) {
d3 += d0;
} else if (d0 > 0.0D) {
d6 += d0;
}
if (d1 < 0.0D) {
d4 += d1;
} else if (d1 > 0.0D) {
d7 += d1;
}
if (d2 < 0.0D) {
d5 += d2;
} else if (d2 > 0.0D) {
d8 += d2;
}
return new AxisAlignedBB(d3, d4, d5, d6, d7, d8);
}
// Paper start
public AxisAlignedBB grow(double d0) {
return grow(d0, d0, d0);
}
// Paper end
public AxisAlignedBB grow(double d0, double d1, double d2) {
double d3 = this.minX - d0;
double d4 = this.minY - d1;
double d5 = this.minZ - d2;
double d6 = this.maxX + d0;
double d7 = this.maxY + d1;
double d8 = this.maxZ + d2;
return new AxisAlignedBB(d3, d4, d5, d6, d7, d8);
}
public AxisAlignedBB g(double d0) {
return this.grow(d0, d0, d0);
}
public AxisAlignedBB a(AxisAlignedBB axisalignedbb) {
double d0 = Math.max(this.minX, axisalignedbb.minX);
double d1 = Math.max(this.minY, axisalignedbb.minY);
double d2 = Math.max(this.minZ, axisalignedbb.minZ);
double d3 = Math.min(this.maxX, axisalignedbb.maxX);
double d4 = Math.min(this.maxY, axisalignedbb.maxY);
double d5 = Math.min(this.maxZ, axisalignedbb.maxZ);
return new AxisAlignedBB(d0, d1, d2, d3, d4, d5);
}
public AxisAlignedBB b(AxisAlignedBB axisalignedbb) {
double d0 = Math.min(this.minX, axisalignedbb.minX);
double d1 = Math.min(this.minY, axisalignedbb.minY);
double d2 = Math.min(this.minZ, axisalignedbb.minZ);
double d3 = Math.max(this.maxX, axisalignedbb.maxX);
double d4 = Math.max(this.maxY, axisalignedbb.maxY);
double d5 = Math.max(this.maxZ, axisalignedbb.maxZ);
return new AxisAlignedBB(d0, d1, d2, d3, d4, d5);
}
public AxisAlignedBB d(double d0, double d1, double d2) {
return new AxisAlignedBB(this.minX + d0, this.minY + d1, this.minZ + d2, this.maxX + d0, this.maxY + d1, this.maxZ + d2);
}
public AxisAlignedBB a(BlockPosition blockposition) {
return new AxisAlignedBB(this.minX + (double) blockposition.getX(), this.minY + (double) blockposition.getY(), this.minZ + (double) blockposition.getZ(), this.maxX + (double) blockposition.getX(), this.maxY + (double) blockposition.getY(), this.maxZ + (double) blockposition.getZ());
}
public AxisAlignedBB a(Vec3D vec3d) {
return this.d(vec3d.x, vec3d.y, vec3d.z);
}
public boolean c(AxisAlignedBB axisalignedbb) {
return this.a(axisalignedbb.minX, axisalignedbb.minY, axisalignedbb.minZ, axisalignedbb.maxX, axisalignedbb.maxY, axisalignedbb.maxZ);
}
public boolean a(double d0, double d1, double d2, double d3, double d4, double d5) {
return this.minX < d3 && this.maxX > d0 && this.minY < d4 && this.maxY > d1 && this.minZ < d5 && this.maxZ > d2;
}
public boolean contains(Vec3D vec3d) { return b(vec3d); } // Paper - OBFHELPER
public boolean b(Vec3D vec3d) {
return this.e(vec3d.x, vec3d.y, vec3d.z);
}
public boolean e(double d0, double d1, double d2) {
return d0 >= this.minX && d0 < this.maxX && d1 >= this.minY && d1 < this.maxY && d2 >= this.minZ && d2 < this.maxZ;
}
public double a() {
double d0 = this.maxX - this.minX;
double d1 = this.maxY - this.minY;
double d2 = this.maxZ - this.minZ;
return (d0 + d1 + d2) / 3.0D;
}
public AxisAlignedBB f(double d0, double d1, double d2) {
return this.grow(-d0, -d1, -d2);
}
public AxisAlignedBB shrink(double d0) {
return this.g(-d0);
}
public MovingObjectPosition calculateIntercept(Vec3D vec3d, Vec3D vec3d1) { return b(vec3d, vec3d1); } // Paper - OBFHELPER
@Nullable
public MovingObjectPosition b(Vec3D vec3d, Vec3D vec3d1) {
return this.a(vec3d, vec3d1, (BlockPosition) null);
}
@Nullable
public MovingObjectPosition a(Vec3D vec3d, Vec3D vec3d1, @Nullable BlockPosition blockposition) {
double[] adouble = new double[] { 1.0D};
EnumDirection enumdirection = null;
double d0 = vec3d1.x - vec3d.x;
double d1 = vec3d1.y - vec3d.y;
double d2 = vec3d1.z - vec3d.z;
enumdirection = a(blockposition == null ? this : this.a(blockposition), vec3d, adouble, enumdirection, d0, d1, d2);
if (enumdirection == null) {
return null;
} else {
double d3 = adouble[0];
return new MovingObjectPosition(vec3d.add(d3 * d0, d3 * d1, d3 * d2), enumdirection, blockposition == null ? BlockPosition.ZERO : blockposition);
}
}
@Nullable
public static MovingObjectPosition a(Iterable<AxisAlignedBB> iterable, Vec3D vec3d, Vec3D vec3d1, BlockPosition blockposition) {
double[] adouble = new double[] { 1.0D};
EnumDirection enumdirection = null;
double d0 = vec3d1.x - vec3d.x;
double d1 = vec3d1.y - vec3d.y;
double d2 = vec3d1.z - vec3d.z;
AxisAlignedBB axisalignedbb;
for (Iterator iterator = iterable.iterator(); iterator.hasNext(); enumdirection = a(axisalignedbb.a(blockposition), vec3d, adouble, enumdirection, d0, d1, d2)) {
axisalignedbb = (AxisAlignedBB) iterator.next();
}
if (enumdirection == null) {
return null;
} else {
double d3 = adouble[0];
return new MovingObjectPosition(vec3d.add(d3 * d0, d3 * d1, d3 * d2), enumdirection, blockposition);
}
}
@Nullable
private static EnumDirection a(AxisAlignedBB axisalignedbb, Vec3D vec3d, double[] adouble, @Nullable EnumDirection enumdirection, double d0, double d1, double d2) {
if (d0 > 1.0E-7D) {
enumdirection = a(adouble, enumdirection, d0, d1, d2, axisalignedbb.minX, axisalignedbb.minY, axisalignedbb.maxY, axisalignedbb.minZ, axisalignedbb.maxZ, EnumDirection.WEST, vec3d.x, vec3d.y, vec3d.z);
} else if (d0 < -1.0E-7D) {
enumdirection = a(adouble, enumdirection, d0, d1, d2, axisalignedbb.maxX, axisalignedbb.minY, axisalignedbb.maxY, axisalignedbb.minZ, axisalignedbb.maxZ, EnumDirection.EAST, vec3d.x, vec3d.y, vec3d.z);
}
if (d1 > 1.0E-7D) {
enumdirection = a(adouble, enumdirection, d1, d2, d0, axisalignedbb.minY, axisalignedbb.minZ, axisalignedbb.maxZ, axisalignedbb.minX, axisalignedbb.maxX, EnumDirection.DOWN, vec3d.y, vec3d.z, vec3d.x);
} else if (d1 < -1.0E-7D) {
enumdirection = a(adouble, enumdirection, d1, d2, d0, axisalignedbb.maxY, axisalignedbb.minZ, axisalignedbb.maxZ, axisalignedbb.minX, axisalignedbb.maxX, EnumDirection.UP, vec3d.y, vec3d.z, vec3d.x);
}
if (d2 > 1.0E-7D) {
enumdirection = a(adouble, enumdirection, d2, d0, d1, axisalignedbb.minZ, axisalignedbb.minX, axisalignedbb.maxX, axisalignedbb.minY, axisalignedbb.maxY, EnumDirection.NORTH, vec3d.z, vec3d.x, vec3d.y);
} else if (d2 < -1.0E-7D) {
enumdirection = a(adouble, enumdirection, d2, d0, d1, axisalignedbb.maxZ, axisalignedbb.minX, axisalignedbb.maxX, axisalignedbb.minY, axisalignedbb.maxY, EnumDirection.SOUTH, vec3d.z, vec3d.x, vec3d.y);
}
return enumdirection;
}
@Nullable
private static EnumDirection a(double[] adouble, @Nullable EnumDirection enumdirection, double d0, double d1, double d2, double d3, double d4, double d5, double d6, double d7, EnumDirection enumdirection1, double d8, double d9, double d10) {
double d11 = (d3 - d8) / d0;
double d12 = d9 + d11 * d1;
double d13 = d10 + d11 * d2;
if (0.0D < d11 && d11 < adouble[0] && d4 - 1.0E-7D < d12 && d12 < d5 + 1.0E-7D && d6 - 1.0E-7D < d13 && d13 < d7 + 1.0E-7D) {
adouble[0] = d11;
return enumdirection1;
} else {
return enumdirection;
}
}
public String toString() {
return "box[" + this.minX + ", " + this.minY + ", " + this.minZ + " -> " + this.maxX + ", " + this.maxY + ", " + this.maxZ + "]";
}
}