2011-06-12 00:02:58 +02:00
|
|
|
package net.minecraft.server;
|
|
|
|
|
|
|
|
import java.util.Random;
|
|
|
|
|
|
|
|
// CraftBukkit start
|
|
|
|
import org.bukkit.event.world.PortalCreateEvent;
|
|
|
|
import org.bukkit.Bukkit;
|
|
|
|
// CraftBukkit end
|
|
|
|
|
|
|
|
public class PortalTravelAgent {
|
|
|
|
|
|
|
|
private Random a = new Random();
|
|
|
|
|
|
|
|
public PortalTravelAgent() {}
|
|
|
|
|
|
|
|
public void a(World world, Entity entity) {
|
|
|
|
if (!this.b(world, entity)) {
|
|
|
|
this.c(world, entity);
|
|
|
|
this.b(world, entity);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
public boolean b(World world, Entity entity) {
|
|
|
|
short short1 = 128;
|
|
|
|
double d0 = -1.0D;
|
|
|
|
int i = 0;
|
|
|
|
int j = 0;
|
|
|
|
int k = 0;
|
|
|
|
int l = MathHelper.floor(entity.locX);
|
|
|
|
int i1 = MathHelper.floor(entity.locZ);
|
|
|
|
|
|
|
|
double d1;
|
|
|
|
|
|
|
|
for (int j1 = l - short1; j1 <= l + short1; ++j1) {
|
|
|
|
double d2 = (double) j1 + 0.5D - entity.locX;
|
|
|
|
|
|
|
|
for (int k1 = i1 - short1; k1 <= i1 + short1; ++k1) {
|
|
|
|
double d3 = (double) k1 + 0.5D - entity.locZ;
|
|
|
|
|
2011-09-15 02:23:52 +02:00
|
|
|
world.getClass();
|
|
|
|
|
|
|
|
for (int l1 = 128 - 1; l1 >= 0; --l1) {
|
2011-06-12 00:02:58 +02:00
|
|
|
if (world.getTypeId(j1, l1, k1) == Block.PORTAL.id) {
|
|
|
|
while (world.getTypeId(j1, l1 - 1, k1) == Block.PORTAL.id) {
|
|
|
|
--l1;
|
|
|
|
}
|
|
|
|
|
|
|
|
d1 = (double) l1 + 0.5D - entity.locY;
|
|
|
|
double d4 = d2 * d2 + d1 * d1 + d3 * d3;
|
|
|
|
|
|
|
|
if (d0 < 0.0D || d4 < d0) {
|
|
|
|
d0 = d4;
|
|
|
|
i = j1;
|
|
|
|
j = l1;
|
|
|
|
k = k1;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
if (d0 >= 0.0D) {
|
|
|
|
double d5 = (double) i + 0.5D;
|
|
|
|
double d6 = (double) j + 0.5D;
|
|
|
|
|
|
|
|
d1 = (double) k + 0.5D;
|
|
|
|
if (world.getTypeId(i - 1, j, k) == Block.PORTAL.id) {
|
|
|
|
d5 -= 0.5D;
|
|
|
|
}
|
|
|
|
|
|
|
|
if (world.getTypeId(i + 1, j, k) == Block.PORTAL.id) {
|
|
|
|
d5 += 0.5D;
|
|
|
|
}
|
|
|
|
|
|
|
|
if (world.getTypeId(i, j, k - 1) == Block.PORTAL.id) {
|
|
|
|
d1 -= 0.5D;
|
|
|
|
}
|
|
|
|
|
|
|
|
if (world.getTypeId(i, j, k + 1) == Block.PORTAL.id) {
|
|
|
|
d1 += 0.5D;
|
|
|
|
}
|
|
|
|
|
|
|
|
entity.setPositionRotation(d5, d6, d1, entity.yaw, 0.0F);
|
|
|
|
entity.motX = entity.motY = entity.motZ = 0.0D;
|
|
|
|
return true;
|
|
|
|
} else {
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
public boolean c(World world, Entity entity) {
|
|
|
|
byte b0 = 16;
|
|
|
|
double d0 = -1.0D;
|
|
|
|
int i = MathHelper.floor(entity.locX);
|
|
|
|
int j = MathHelper.floor(entity.locY);
|
|
|
|
int k = MathHelper.floor(entity.locZ);
|
|
|
|
int l = i;
|
|
|
|
int i1 = j;
|
|
|
|
int j1 = k;
|
|
|
|
int k1 = 0;
|
|
|
|
int l1 = this.a.nextInt(4);
|
|
|
|
|
|
|
|
int i2;
|
|
|
|
double d1;
|
|
|
|
int j2;
|
|
|
|
double d2;
|
|
|
|
int k2;
|
|
|
|
int l2;
|
|
|
|
int i3;
|
|
|
|
int j3;
|
|
|
|
int k3;
|
|
|
|
int l3;
|
|
|
|
int i4;
|
|
|
|
int j4;
|
|
|
|
int k4;
|
|
|
|
double d3;
|
|
|
|
double d4;
|
|
|
|
|
|
|
|
for (i2 = i - b0; i2 <= i + b0; ++i2) {
|
|
|
|
d1 = (double) i2 + 0.5D - entity.locX;
|
|
|
|
|
|
|
|
for (j2 = k - b0; j2 <= k + b0; ++j2) {
|
|
|
|
d2 = (double) j2 + 0.5D - entity.locZ;
|
2011-09-15 02:23:52 +02:00
|
|
|
world.getClass();
|
2011-06-12 00:02:58 +02:00
|
|
|
|
2011-09-15 02:23:52 +02:00
|
|
|
label274:
|
|
|
|
for (l2 = 128 - 1; l2 >= 0; --l2) {
|
2011-06-12 00:02:58 +02:00
|
|
|
if (world.isEmpty(i2, l2, j2)) {
|
|
|
|
while (l2 > 0 && world.isEmpty(i2, l2 - 1, j2)) {
|
|
|
|
--l2;
|
|
|
|
}
|
|
|
|
|
|
|
|
for (k2 = l1; k2 < l1 + 4; ++k2) {
|
|
|
|
j3 = k2 % 2;
|
|
|
|
i3 = 1 - j3;
|
|
|
|
if (k2 % 4 >= 2) {
|
|
|
|
j3 = -j3;
|
|
|
|
i3 = -i3;
|
|
|
|
}
|
|
|
|
|
|
|
|
for (l3 = 0; l3 < 3; ++l3) {
|
|
|
|
for (k3 = 0; k3 < 4; ++k3) {
|
|
|
|
for (j4 = -1; j4 < 4; ++j4) {
|
|
|
|
i4 = i2 + (k3 - 1) * j3 + l3 * i3;
|
|
|
|
k4 = l2 + j4;
|
|
|
|
int l4 = j2 + (k3 - 1) * i3 - l3 * j3;
|
|
|
|
|
|
|
|
if (j4 < 0 && !world.getMaterial(i4, k4, l4).isBuildable() || j4 >= 0 && !world.isEmpty(i4, k4, l4)) {
|
2011-09-15 02:23:52 +02:00
|
|
|
continue label274;
|
2011-06-12 00:02:58 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
d3 = (double) l2 + 0.5D - entity.locY;
|
|
|
|
d4 = d1 * d1 + d3 * d3 + d2 * d2;
|
|
|
|
if (d0 < 0.0D || d4 < d0) {
|
|
|
|
d0 = d4;
|
|
|
|
l = i2;
|
|
|
|
i1 = l2;
|
|
|
|
j1 = j2;
|
|
|
|
k1 = k2 % 4;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
if (d0 < 0.0D) {
|
|
|
|
for (i2 = i - b0; i2 <= i + b0; ++i2) {
|
|
|
|
d1 = (double) i2 + 0.5D - entity.locX;
|
|
|
|
|
|
|
|
for (j2 = k - b0; j2 <= k + b0; ++j2) {
|
|
|
|
d2 = (double) j2 + 0.5D - entity.locZ;
|
2011-09-15 02:23:52 +02:00
|
|
|
world.getClass();
|
2011-06-12 00:02:58 +02:00
|
|
|
|
2011-09-15 02:23:52 +02:00
|
|
|
label222:
|
|
|
|
for (l2 = 128 - 1; l2 >= 0; --l2) {
|
2011-06-12 00:02:58 +02:00
|
|
|
if (world.isEmpty(i2, l2, j2)) {
|
2011-09-15 02:23:52 +02:00
|
|
|
while (l2 > 0 && world.isEmpty(i2, l2 - 1, j2)) {
|
2011-06-12 00:02:58 +02:00
|
|
|
--l2;
|
|
|
|
}
|
|
|
|
|
|
|
|
for (k2 = l1; k2 < l1 + 2; ++k2) {
|
|
|
|
j3 = k2 % 2;
|
|
|
|
i3 = 1 - j3;
|
|
|
|
|
|
|
|
for (l3 = 0; l3 < 4; ++l3) {
|
|
|
|
for (k3 = -1; k3 < 4; ++k3) {
|
|
|
|
j4 = i2 + (l3 - 1) * j3;
|
|
|
|
i4 = l2 + k3;
|
|
|
|
k4 = j2 + (l3 - 1) * i3;
|
|
|
|
if (k3 < 0 && !world.getMaterial(j4, i4, k4).isBuildable() || k3 >= 0 && !world.isEmpty(j4, i4, k4)) {
|
2011-09-15 02:23:52 +02:00
|
|
|
continue label222;
|
2011-06-12 00:02:58 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
d3 = (double) l2 + 0.5D - entity.locY;
|
|
|
|
d4 = d1 * d1 + d3 * d3 + d2 * d2;
|
|
|
|
if (d0 < 0.0D || d4 < d0) {
|
|
|
|
d0 = d4;
|
|
|
|
l = i2;
|
|
|
|
i1 = l2;
|
|
|
|
j1 = j2;
|
|
|
|
k1 = k2 % 2;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
int i5 = l;
|
|
|
|
int j5 = i1;
|
|
|
|
|
|
|
|
j2 = j1;
|
|
|
|
int k5 = k1 % 2;
|
|
|
|
int l5 = 1 - k5;
|
|
|
|
|
|
|
|
if (k1 % 4 >= 2) {
|
|
|
|
k5 = -k5;
|
|
|
|
l5 = -l5;
|
|
|
|
}
|
|
|
|
|
|
|
|
boolean flag;
|
|
|
|
|
|
|
|
// CraftBukkit start - portal create event
|
2011-06-27 00:25:01 +02:00
|
|
|
java.util.Collection<org.bukkit.block.Block> blocks = new java.util.HashSet<org.bukkit.block.Block>();
|
2011-06-12 00:02:58 +02:00
|
|
|
// Find out what blocks the portal is going to modify, duplicated from below
|
2011-06-27 00:25:01 +02:00
|
|
|
org.bukkit.World bworld = world.getWorld();
|
2011-06-12 00:02:58 +02:00
|
|
|
|
|
|
|
if (d0 < 0.0D) {
|
|
|
|
if (i1 < 70) {
|
|
|
|
i1 = 70;
|
|
|
|
}
|
|
|
|
|
|
|
|
if (i1 > 118) {
|
|
|
|
i1 = 118;
|
|
|
|
}
|
|
|
|
|
|
|
|
j5 = i1;
|
|
|
|
|
|
|
|
for (l2 = -1; l2 <= 1; ++l2) {
|
|
|
|
for (k2 = 1; k2 < 3; ++k2) {
|
|
|
|
for (j3 = -1; j3 < 3; ++j3) {
|
|
|
|
i3 = i5 + (k2 - 1) * k5 + l2 * l5;
|
|
|
|
l3 = j5 + j3;
|
|
|
|
k3 = j2 + (k2 - 1) * l5 - l2 * k5;
|
2011-06-27 00:25:01 +02:00
|
|
|
blocks.add(bworld.getBlockAt(i3, l3, k3));
|
2011-06-12 00:02:58 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
for (l2 = 0; l2 < 4; ++l2) {
|
|
|
|
for (k2 = 0; k2 < 4; ++k2) {
|
|
|
|
for (j3 = -1; j3 < 4; ++j3) {
|
|
|
|
i3 = i5 + (k2 - 1) * k5;
|
|
|
|
l3 = j5 + j3;
|
|
|
|
k3 = j2 + (k2 - 1) * l5;
|
2011-06-27 00:25:01 +02:00
|
|
|
blocks.add(bworld.getBlockAt(i3, l3, k3));
|
2011-06-12 00:02:58 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2011-06-27 00:25:01 +02:00
|
|
|
PortalCreateEvent event = new PortalCreateEvent(blocks, bworld);
|
2011-06-12 00:02:58 +02:00
|
|
|
Bukkit.getServer().getPluginManager().callEvent(event);
|
2011-06-27 00:25:01 +02:00
|
|
|
|
2011-06-12 00:02:58 +02:00
|
|
|
if (event.isCancelled()) {
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
// CraftBukkit end
|
|
|
|
|
|
|
|
if (d0 < 0.0D) {
|
|
|
|
if (i1 < 70) {
|
|
|
|
i1 = 70;
|
|
|
|
}
|
|
|
|
|
2011-09-15 02:23:52 +02:00
|
|
|
world.getClass();
|
|
|
|
if (i1 > 128 - 10) {
|
|
|
|
world.getClass();
|
|
|
|
i1 = 128 - 10;
|
2011-06-12 00:02:58 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
j5 = i1;
|
|
|
|
|
|
|
|
for (l2 = -1; l2 <= 1; ++l2) {
|
|
|
|
for (k2 = 1; k2 < 3; ++k2) {
|
|
|
|
for (j3 = -1; j3 < 3; ++j3) {
|
|
|
|
i3 = i5 + (k2 - 1) * k5 + l2 * l5;
|
|
|
|
l3 = j5 + j3;
|
|
|
|
k3 = j2 + (k2 - 1) * l5 - l2 * k5;
|
|
|
|
flag = j3 < 0;
|
|
|
|
world.setTypeId(i3, l3, k3, flag ? Block.OBSIDIAN.id : 0);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
for (l2 = 0; l2 < 4; ++l2) {
|
2011-06-27 00:25:01 +02:00
|
|
|
world.suppressPhysics = true;
|
2011-06-12 00:02:58 +02:00
|
|
|
|
|
|
|
for (k2 = 0; k2 < 4; ++k2) {
|
|
|
|
for (j3 = -1; j3 < 4; ++j3) {
|
|
|
|
i3 = i5 + (k2 - 1) * k5;
|
|
|
|
l3 = j5 + j3;
|
|
|
|
k3 = j2 + (k2 - 1) * l5;
|
|
|
|
flag = k2 == 0 || k2 == 3 || j3 == -1 || j3 == 3;
|
|
|
|
world.setTypeId(i3, l3, k3, flag ? Block.OBSIDIAN.id : Block.PORTAL.id);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2011-06-27 00:25:01 +02:00
|
|
|
world.suppressPhysics = false;
|
2011-06-12 00:02:58 +02:00
|
|
|
|
|
|
|
for (k2 = 0; k2 < 4; ++k2) {
|
|
|
|
for (j3 = -1; j3 < 4; ++j3) {
|
|
|
|
i3 = i5 + (k2 - 1) * k5;
|
|
|
|
l3 = j5 + j3;
|
|
|
|
k3 = j2 + (k2 - 1) * l5;
|
|
|
|
world.applyPhysics(i3, l3, k3, world.getTypeId(i3, l3, k3));
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
}
|