mirror of
https://github.com/PaperMC/Paper.git
synced 2025-01-22 08:15:05 +01:00
Process entity portalling towards the end of a tick.
Cross world teleportation works by taking a copy of an entity and moving it to a new world. After this happens the original entity is marked as dead so as to be removed from the original world, however it still undergoes one further tick in the main world, but with some information from the new world. It is not so easy to break out of this tick cycle if needed, so instead we move the portalling process towards the end of an existing tick. This ensures that the entity will not be spuriously ticked.
This commit is contained in:
parent
b80055abfb
commit
257d6cd04f
2 changed files with 115 additions and 40 deletions
|
@ -93,7 +93,66 @@
|
||||||
this.yaw = f % 360.0F;
|
this.yaw = f % 360.0F;
|
||||||
this.pitch = f1 % 360.0F;
|
this.pitch = f1 % 360.0F;
|
||||||
}
|
}
|
||||||
@@ -249,7 +319,7 @@
|
@@ -228,6 +298,51 @@
|
||||||
|
this.U();
|
||||||
|
}
|
||||||
|
|
||||||
|
+ // CraftBukkit start
|
||||||
|
+ public void postTick() {
|
||||||
|
+ // No clean way to break out of ticking once the entity has been copied to a new world, so instead we move the portalling later in the tick cycle
|
||||||
|
+ if (!this.world.isClientSide && this.world instanceof WorldServer) {
|
||||||
|
+ this.world.methodProfiler.a("portal");
|
||||||
|
+ if (this.ak) {
|
||||||
|
+ MinecraftServer minecraftserver = this.world.getMinecraftServer();
|
||||||
|
+
|
||||||
|
+ if (true || minecraftserver.getAllowNether()) { // CraftBukkit
|
||||||
|
+ if (!this.isPassenger()) {
|
||||||
|
+ int i = this.V();
|
||||||
|
+
|
||||||
|
+ if (this.al++ >= i) {
|
||||||
|
+ this.al = i;
|
||||||
|
+ this.portalCooldown = this.aE();
|
||||||
|
+ byte b0;
|
||||||
|
+
|
||||||
|
+ if (this.world.worldProvider.getDimensionManager().getDimensionID() == -1) {
|
||||||
|
+ b0 = 0;
|
||||||
|
+ } else {
|
||||||
|
+ b0 = -1;
|
||||||
|
+ }
|
||||||
|
+
|
||||||
|
+ this.c(b0);
|
||||||
|
+ }
|
||||||
|
+ }
|
||||||
|
+
|
||||||
|
+ this.ak = false;
|
||||||
|
+ }
|
||||||
|
+ } else {
|
||||||
|
+ if (this.al > 0) {
|
||||||
|
+ this.al -= 4;
|
||||||
|
+ }
|
||||||
|
+
|
||||||
|
+ if (this.al < 0) {
|
||||||
|
+ this.al = 0;
|
||||||
|
+ }
|
||||||
|
+ }
|
||||||
|
+
|
||||||
|
+ this.H();
|
||||||
|
+ this.world.methodProfiler.b();
|
||||||
|
+ }
|
||||||
|
+ }
|
||||||
|
+ // CraftBukkit end
|
||||||
|
+
|
||||||
|
public void U() {
|
||||||
|
this.world.methodProfiler.a("entityBaseTick");
|
||||||
|
if (this.isPassenger() && this.bB().dead) {
|
||||||
|
@@ -244,12 +359,14 @@
|
||||||
|
this.lastZ = this.locZ;
|
||||||
|
this.lastPitch = this.pitch;
|
||||||
|
this.lastYaw = this.yaw;
|
||||||
|
+ // Moved up to postTick
|
||||||
|
+ /*
|
||||||
|
if (!this.world.isClientSide && this.world instanceof WorldServer) {
|
||||||
|
this.world.methodProfiler.a("portal");
|
||||||
if (this.ak) {
|
if (this.ak) {
|
||||||
MinecraftServer minecraftserver = this.world.getMinecraftServer();
|
MinecraftServer minecraftserver = this.world.getMinecraftServer();
|
||||||
|
|
||||||
|
@ -102,7 +161,15 @@
|
||||||
if (!this.isPassenger()) {
|
if (!this.isPassenger()) {
|
||||||
int i = this.V();
|
int i = this.V();
|
||||||
|
|
||||||
@@ -334,6 +404,27 @@
|
@@ -283,6 +400,7 @@
|
||||||
|
this.H();
|
||||||
|
this.world.methodProfiler.b();
|
||||||
|
}
|
||||||
|
+ */
|
||||||
|
|
||||||
|
this.am();
|
||||||
|
this.ak();
|
||||||
|
@@ -334,6 +452,27 @@
|
||||||
protected void burnFromLava() {
|
protected void burnFromLava() {
|
||||||
if (!this.fireProof) {
|
if (!this.fireProof) {
|
||||||
this.damageEntity(DamageSource.LAVA, 4.0F);
|
this.damageEntity(DamageSource.LAVA, 4.0F);
|
||||||
|
@ -130,7 +197,7 @@
|
||||||
this.setOnFire(15);
|
this.setOnFire(15);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@@ -374,6 +465,22 @@
|
@@ -374,6 +513,22 @@
|
||||||
this.a(this.getBoundingBox().d(d0, d1, d2));
|
this.a(this.getBoundingBox().d(d0, d1, d2));
|
||||||
this.recalcPosition();
|
this.recalcPosition();
|
||||||
} else {
|
} else {
|
||||||
|
@ -153,7 +220,7 @@
|
||||||
if (enummovetype == EnumMoveType.PISTON) {
|
if (enummovetype == EnumMoveType.PISTON) {
|
||||||
long i = this.world.getTime();
|
long i = this.world.getTime();
|
||||||
|
|
||||||
@@ -515,7 +622,7 @@
|
@@ -515,7 +670,7 @@
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -162,7 +229,7 @@
|
||||||
double d11;
|
double d11;
|
||||||
|
|
||||||
if (this.P > 0.0F && flag && (d7 != d0 || d9 != d2)) {
|
if (this.P > 0.0F && flag && (d7 != d0 || d9 != d2)) {
|
||||||
@@ -613,7 +720,7 @@
|
@@ -613,7 +768,7 @@
|
||||||
this.world.methodProfiler.a("rest");
|
this.world.methodProfiler.a("rest");
|
||||||
this.recalcPosition();
|
this.recalcPosition();
|
||||||
this.positionChanged = d7 != d0 || d9 != d2;
|
this.positionChanged = d7 != d0 || d9 != d2;
|
||||||
|
@ -171,7 +238,7 @@
|
||||||
this.onGround = this.B && d8 < 0.0D;
|
this.onGround = this.B && d8 < 0.0D;
|
||||||
this.C = this.positionChanged || this.B;
|
this.C = this.positionChanged || this.B;
|
||||||
l = MathHelper.floor(this.locX);
|
l = MathHelper.floor(this.locX);
|
||||||
@@ -648,6 +755,28 @@
|
@@ -648,6 +803,28 @@
|
||||||
block1.a(this.world, this);
|
block1.a(this.world, this);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -200,7 +267,7 @@
|
||||||
if (this.playStepSound() && (!this.onGround || !this.isSneaking() || !(this instanceof EntityHuman)) && !this.isPassenger()) {
|
if (this.playStepSound() && (!this.onGround || !this.isSneaking() || !(this instanceof EntityHuman)) && !this.isPassenger()) {
|
||||||
double d22 = this.locX - d4;
|
double d22 = this.locX - d4;
|
||||||
double d23 = this.locY - d5;
|
double d23 = this.locY - d5;
|
||||||
@@ -681,6 +810,8 @@
|
@@ -681,6 +858,8 @@
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -209,7 +276,7 @@
|
||||||
try {
|
try {
|
||||||
this.checkBlockCollisions();
|
this.checkBlockCollisions();
|
||||||
} catch (Throwable throwable) {
|
} catch (Throwable throwable) {
|
||||||
@@ -690,6 +821,8 @@
|
@@ -690,6 +869,8 @@
|
||||||
this.appendEntityCrashDetails(crashreportsystemdetails);
|
this.appendEntityCrashDetails(crashreportsystemdetails);
|
||||||
throw new ReportedException(crashreport);
|
throw new ReportedException(crashreport);
|
||||||
}
|
}
|
||||||
|
@ -218,7 +285,7 @@
|
||||||
|
|
||||||
boolean flag1 = this.ai();
|
boolean flag1 = this.ai();
|
||||||
|
|
||||||
@@ -698,7 +831,14 @@
|
@@ -698,7 +879,14 @@
|
||||||
if (!flag1) {
|
if (!flag1) {
|
||||||
++this.fireTicks;
|
++this.fireTicks;
|
||||||
if (this.fireTicks == 0) {
|
if (this.fireTicks == 0) {
|
||||||
|
@ -234,7 +301,7 @@
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
} else if (this.fireTicks <= 0) {
|
} else if (this.fireTicks <= 0) {
|
||||||
@@ -819,7 +959,7 @@
|
@@ -819,7 +1007,7 @@
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -243,7 +310,7 @@
|
||||||
if (!this.fireProof) {
|
if (!this.fireProof) {
|
||||||
this.damageEntity(DamageSource.FIRE, (float) i);
|
this.damageEntity(DamageSource.FIRE, (float) i);
|
||||||
}
|
}
|
||||||
@@ -987,6 +1127,13 @@
|
@@ -987,6 +1175,13 @@
|
||||||
}
|
}
|
||||||
|
|
||||||
public void spawnIn(World world) {
|
public void spawnIn(World world) {
|
||||||
|
@ -257,7 +324,7 @@
|
||||||
this.world = world;
|
this.world = world;
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -1219,6 +1366,18 @@
|
@@ -1219,6 +1414,18 @@
|
||||||
try {
|
try {
|
||||||
nbttagcompound.set("Pos", this.a(new double[] { this.locX, this.locY, this.locZ}));
|
nbttagcompound.set("Pos", this.a(new double[] { this.locX, this.locY, this.locZ}));
|
||||||
nbttagcompound.set("Motion", this.a(new double[] { this.motX, this.motY, this.motZ}));
|
nbttagcompound.set("Motion", this.a(new double[] { this.motX, this.motY, this.motZ}));
|
||||||
|
@ -276,7 +343,7 @@
|
||||||
nbttagcompound.set("Rotation", this.a(new float[] { this.yaw, this.pitch}));
|
nbttagcompound.set("Rotation", this.a(new float[] { this.yaw, this.pitch}));
|
||||||
nbttagcompound.setFloat("FallDistance", this.fallDistance);
|
nbttagcompound.setFloat("FallDistance", this.fallDistance);
|
||||||
nbttagcompound.setShort("Fire", (short) this.fireTicks);
|
nbttagcompound.setShort("Fire", (short) this.fireTicks);
|
||||||
@@ -1228,6 +1387,12 @@
|
@@ -1228,6 +1435,12 @@
|
||||||
nbttagcompound.setBoolean("Invulnerable", this.invulnerable);
|
nbttagcompound.setBoolean("Invulnerable", this.invulnerable);
|
||||||
nbttagcompound.setInt("PortalCooldown", this.portalCooldown);
|
nbttagcompound.setInt("PortalCooldown", this.portalCooldown);
|
||||||
nbttagcompound.a("UUID", this.getUniqueID());
|
nbttagcompound.a("UUID", this.getUniqueID());
|
||||||
|
@ -289,7 +356,7 @@
|
||||||
if (this.hasCustomName()) {
|
if (this.hasCustomName()) {
|
||||||
nbttagcompound.setString("CustomName", this.getCustomName());
|
nbttagcompound.setString("CustomName", this.getCustomName());
|
||||||
}
|
}
|
||||||
@@ -1303,6 +1468,8 @@
|
@@ -1303,6 +1516,8 @@
|
||||||
this.motX = nbttaglist1.e(0);
|
this.motX = nbttaglist1.e(0);
|
||||||
this.motY = nbttaglist1.e(1);
|
this.motY = nbttaglist1.e(1);
|
||||||
this.motZ = nbttaglist1.e(2);
|
this.motZ = nbttaglist1.e(2);
|
||||||
|
@ -298,7 +365,7 @@
|
||||||
if (Math.abs(this.motX) > 10.0D) {
|
if (Math.abs(this.motX) > 10.0D) {
|
||||||
this.motX = 0.0D;
|
this.motX = 0.0D;
|
||||||
}
|
}
|
||||||
@@ -1314,6 +1481,7 @@
|
@@ -1314,6 +1529,7 @@
|
||||||
if (Math.abs(this.motZ) > 10.0D) {
|
if (Math.abs(this.motZ) > 10.0D) {
|
||||||
this.motZ = 0.0D;
|
this.motZ = 0.0D;
|
||||||
}
|
}
|
||||||
|
@ -306,7 +373,7 @@
|
||||||
|
|
||||||
this.locX = nbttaglist.e(0);
|
this.locX = nbttaglist.e(0);
|
||||||
this.locY = nbttaglist.e(1);
|
this.locY = nbttaglist.e(1);
|
||||||
@@ -1371,6 +1539,58 @@
|
@@ -1371,6 +1587,58 @@
|
||||||
this.setPosition(this.locX, this.locY, this.locZ);
|
this.setPosition(this.locX, this.locY, this.locZ);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -365,7 +432,7 @@
|
||||||
} catch (Throwable throwable) {
|
} catch (Throwable throwable) {
|
||||||
CrashReport crashreport = CrashReport.a(throwable, "Loading entity NBT");
|
CrashReport crashreport = CrashReport.a(throwable, "Loading entity NBT");
|
||||||
CrashReportSystemDetails crashreportsystemdetails = crashreport.a("Entity being loaded");
|
CrashReportSystemDetails crashreportsystemdetails = crashreport.a("Entity being loaded");
|
||||||
@@ -1438,6 +1658,12 @@
|
@@ -1438,6 +1706,12 @@
|
||||||
if (itemstack.isEmpty()) {
|
if (itemstack.isEmpty()) {
|
||||||
return null;
|
return null;
|
||||||
} else {
|
} else {
|
||||||
|
@ -378,7 +445,7 @@
|
||||||
EntityItem entityitem = new EntityItem(this.world, this.locX, this.locY + (double) f, this.locZ, itemstack);
|
EntityItem entityitem = new EntityItem(this.world, this.locX, this.locY + (double) f, this.locZ, itemstack);
|
||||||
|
|
||||||
entityitem.q();
|
entityitem.q();
|
||||||
@@ -1563,6 +1789,24 @@
|
@@ -1563,6 +1837,24 @@
|
||||||
if (entity.bB() != this) {
|
if (entity.bB() != this) {
|
||||||
throw new IllegalStateException("Use x.startRiding(y), not y.addPassenger(x)");
|
throw new IllegalStateException("Use x.startRiding(y), not y.addPassenger(x)");
|
||||||
} else {
|
} else {
|
||||||
|
@ -403,7 +470,7 @@
|
||||||
if (!this.world.isClientSide && entity instanceof EntityHuman && !(this.bw() instanceof EntityHuman)) {
|
if (!this.world.isClientSide && entity instanceof EntityHuman && !(this.bw() instanceof EntityHuman)) {
|
||||||
this.passengers.add(0, entity);
|
this.passengers.add(0, entity);
|
||||||
} else {
|
} else {
|
||||||
@@ -1576,6 +1820,22 @@
|
@@ -1576,6 +1868,22 @@
|
||||||
if (entity.bB() == this) {
|
if (entity.bB() == this) {
|
||||||
throw new IllegalStateException("Use x.stopRiding(y), not y.removePassenger(x)");
|
throw new IllegalStateException("Use x.stopRiding(y), not y.removePassenger(x)");
|
||||||
} else {
|
} else {
|
||||||
|
@ -426,7 +493,7 @@
|
||||||
this.passengers.remove(entity);
|
this.passengers.remove(entity);
|
||||||
entity.j = 60;
|
entity.j = 60;
|
||||||
}
|
}
|
||||||
@@ -1715,14 +1975,49 @@
|
@@ -1715,14 +2023,49 @@
|
||||||
}
|
}
|
||||||
|
|
||||||
public void setAirTicks(int i) {
|
public void setAirTicks(int i) {
|
||||||
|
@ -479,7 +546,7 @@
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
@@ -1867,19 +2162,70 @@
|
@@ -1867,19 +2210,70 @@
|
||||||
if (!this.world.isClientSide && !this.dead) {
|
if (!this.world.isClientSide && !this.dead) {
|
||||||
this.world.methodProfiler.a("changeDimension");
|
this.world.methodProfiler.a("changeDimension");
|
||||||
MinecraftServer minecraftserver = this.B_();
|
MinecraftServer minecraftserver = this.B_();
|
||||||
|
@ -553,7 +620,7 @@
|
||||||
BlockPosition blockposition;
|
BlockPosition blockposition;
|
||||||
|
|
||||||
if (i == 1) {
|
if (i == 1) {
|
||||||
@@ -1908,12 +2254,18 @@
|
@@ -1908,12 +2302,18 @@
|
||||||
blockposition = new BlockPosition(this);
|
blockposition = new BlockPosition(this);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -573,7 +640,7 @@
|
||||||
if (j == 1 && i == 1) {
|
if (j == 1 && i == 1) {
|
||||||
BlockPosition blockposition1 = worldserver1.q(worldserver1.getSpawn());
|
BlockPosition blockposition1 = worldserver1.q(worldserver1.getSpawn());
|
||||||
|
|
||||||
@@ -1921,6 +2273,7 @@
|
@@ -1921,6 +2321,7 @@
|
||||||
} else {
|
} else {
|
||||||
entity.setPositionRotation(blockposition, entity.yaw, entity.pitch);
|
entity.setPositionRotation(blockposition, entity.yaw, entity.pitch);
|
||||||
}
|
}
|
||||||
|
@ -581,7 +648,7 @@
|
||||||
|
|
||||||
boolean flag = entity.attachedToPlayer;
|
boolean flag = entity.attachedToPlayer;
|
||||||
|
|
||||||
@@ -1928,13 +2281,21 @@
|
@@ -1928,13 +2329,21 @@
|
||||||
worldserver1.addEntity(entity);
|
worldserver1.addEntity(entity);
|
||||||
entity.attachedToPlayer = flag;
|
entity.attachedToPlayer = flag;
|
||||||
worldserver1.entityJoinedWorld(entity, false);
|
worldserver1.entityJoinedWorld(entity, false);
|
||||||
|
@ -604,7 +671,7 @@
|
||||||
return entity;
|
return entity;
|
||||||
} else {
|
} else {
|
||||||
return null;
|
return null;
|
||||||
@@ -2038,6 +2399,11 @@
|
@@ -2038,6 +2447,11 @@
|
||||||
}
|
}
|
||||||
|
|
||||||
public void setCustomName(String s) {
|
public void setCustomName(String s) {
|
||||||
|
@ -616,7 +683,7 @@
|
||||||
this.datawatcher.set(Entity.aA, s);
|
this.datawatcher.set(Entity.aA, s);
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -2095,7 +2461,26 @@
|
@@ -2095,7 +2509,26 @@
|
||||||
}
|
}
|
||||||
|
|
||||||
public void a(AxisAlignedBB axisalignedbb) {
|
public void a(AxisAlignedBB axisalignedbb) {
|
||||||
|
@ -644,7 +711,7 @@
|
||||||
}
|
}
|
||||||
|
|
||||||
public float getHeadHeight() {
|
public float getHeadHeight() {
|
||||||
@@ -2269,7 +2654,7 @@
|
@@ -2269,7 +2702,7 @@
|
||||||
for (Iterator iterator = this.bx().iterator(); iterator.hasNext(); entity.a(oclass, set)) {
|
for (Iterator iterator = this.bx().iterator(); iterator.hasNext(); entity.a(oclass, set)) {
|
||||||
entity = (Entity) iterator.next();
|
entity = (Entity) iterator.next();
|
||||||
if (oclass.isAssignableFrom(entity.getClass())) {
|
if (oclass.isAssignableFrom(entity.getClass())) {
|
||||||
|
|
|
@ -460,7 +460,15 @@
|
||||||
entity.M = entity.locX;
|
entity.M = entity.locX;
|
||||||
entity.N = entity.locY;
|
entity.N = entity.locY;
|
||||||
entity.O = entity.locZ;
|
entity.O = entity.locZ;
|
||||||
@@ -1547,11 +1799,18 @@
|
@@ -1255,6 +1507,7 @@
|
||||||
|
entity.aw();
|
||||||
|
} else {
|
||||||
|
entity.A_();
|
||||||
|
+ entity.postTick(); // CraftBukkit
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
@@ -1547,11 +1800,18 @@
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -479,7 +487,7 @@
|
||||||
TileEntity tileentity = null;
|
TileEntity tileentity = null;
|
||||||
|
|
||||||
if (this.M) {
|
if (this.M) {
|
||||||
@@ -1586,6 +1845,14 @@
|
@@ -1586,6 +1846,14 @@
|
||||||
public void setTileEntity(BlockPosition blockposition, @Nullable TileEntity tileentity) {
|
public void setTileEntity(BlockPosition blockposition, @Nullable TileEntity tileentity) {
|
||||||
if (!this.E(blockposition)) {
|
if (!this.E(blockposition)) {
|
||||||
if (tileentity != null && !tileentity.y()) {
|
if (tileentity != null && !tileentity.y()) {
|
||||||
|
@ -494,7 +502,7 @@
|
||||||
if (this.M) {
|
if (this.M) {
|
||||||
tileentity.setPosition(blockposition);
|
tileentity.setPosition(blockposition);
|
||||||
Iterator iterator = this.b.iterator();
|
Iterator iterator = this.b.iterator();
|
||||||
@@ -1745,6 +2012,14 @@
|
@@ -1745,6 +2013,14 @@
|
||||||
}
|
}
|
||||||
|
|
||||||
this.o = MathHelper.a(this.o, 0.0F, 1.0F);
|
this.o = MathHelper.a(this.o, 0.0F, 1.0F);
|
||||||
|
@ -509,7 +517,7 @@
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@@ -1876,7 +2151,10 @@
|
@@ -1876,7 +2152,10 @@
|
||||||
}
|
}
|
||||||
|
|
||||||
public boolean c(EnumSkyBlock enumskyblock, BlockPosition blockposition) {
|
public boolean c(EnumSkyBlock enumskyblock, BlockPosition blockposition) {
|
||||||
|
@ -521,7 +529,7 @@
|
||||||
return false;
|
return false;
|
||||||
} else {
|
} else {
|
||||||
int i = 0;
|
int i = 0;
|
||||||
@@ -2043,7 +2321,7 @@
|
@@ -2043,7 +2322,7 @@
|
||||||
while (iterator.hasNext()) {
|
while (iterator.hasNext()) {
|
||||||
Entity entity = (Entity) iterator.next();
|
Entity entity = (Entity) iterator.next();
|
||||||
|
|
||||||
|
@ -530,7 +538,7 @@
|
||||||
arraylist.add(entity);
|
arraylist.add(entity);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@@ -2058,7 +2336,7 @@
|
@@ -2058,7 +2337,7 @@
|
||||||
while (iterator.hasNext()) {
|
while (iterator.hasNext()) {
|
||||||
Entity entity = (Entity) iterator.next();
|
Entity entity = (Entity) iterator.next();
|
||||||
|
|
||||||
|
@ -539,7 +547,7 @@
|
||||||
arraylist.add(entity);
|
arraylist.add(entity);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@@ -2107,7 +2385,7 @@
|
@@ -2107,7 +2386,7 @@
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -548,7 +556,7 @@
|
||||||
}
|
}
|
||||||
|
|
||||||
@Nullable
|
@Nullable
|
||||||
@@ -2128,8 +2406,17 @@
|
@@ -2128,8 +2407,17 @@
|
||||||
|
|
||||||
while (iterator.hasNext()) {
|
while (iterator.hasNext()) {
|
||||||
Entity entity = (Entity) iterator.next();
|
Entity entity = (Entity) iterator.next();
|
||||||
|
@ -568,7 +576,7 @@
|
||||||
++i;
|
++i;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@@ -2138,12 +2425,18 @@
|
@@ -2138,12 +2426,18 @@
|
||||||
}
|
}
|
||||||
|
|
||||||
public void a(Collection<Entity> collection) {
|
public void a(Collection<Entity> collection) {
|
||||||
|
@ -588,7 +596,7 @@
|
||||||
this.b(entity);
|
this.b(entity);
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -2157,7 +2450,13 @@
|
@@ -2157,7 +2451,13 @@
|
||||||
IBlockData iblockdata = this.getType(blockposition);
|
IBlockData iblockdata = this.getType(blockposition);
|
||||||
AxisAlignedBB axisalignedbb = flag ? null : block.getBlockData().c(this, blockposition);
|
AxisAlignedBB axisalignedbb = flag ? null : block.getBlockData().c(this, blockposition);
|
||||||
|
|
||||||
|
@ -603,7 +611,7 @@
|
||||||
}
|
}
|
||||||
|
|
||||||
public int K() {
|
public int K() {
|
||||||
@@ -2267,6 +2566,11 @@
|
@@ -2267,6 +2567,11 @@
|
||||||
|
|
||||||
for (int i = 0; i < this.players.size(); ++i) {
|
for (int i = 0; i < this.players.size(); ++i) {
|
||||||
EntityHuman entityhuman1 = (EntityHuman) this.players.get(i);
|
EntityHuman entityhuman1 = (EntityHuman) this.players.get(i);
|
||||||
|
@ -615,7 +623,7 @@
|
||||||
|
|
||||||
if (predicate.apply(entityhuman1)) {
|
if (predicate.apply(entityhuman1)) {
|
||||||
double d5 = entityhuman1.d(d0, d1, d2);
|
double d5 = entityhuman1.d(d0, d1, d2);
|
||||||
@@ -2435,6 +2739,16 @@
|
@@ -2435,6 +2740,16 @@
|
||||||
|
|
||||||
public void everyoneSleeping() {}
|
public void everyoneSleeping() {}
|
||||||
|
|
||||||
|
@ -632,7 +640,7 @@
|
||||||
public float h(float f) {
|
public float h(float f) {
|
||||||
return (this.p + (this.q - this.p) * f) * this.j(f);
|
return (this.p + (this.q - this.p) * f) * this.j(f);
|
||||||
}
|
}
|
||||||
@@ -2652,7 +2966,7 @@
|
@@ -2652,7 +2967,7 @@
|
||||||
int l = j * 16 + 8 - blockposition.getZ();
|
int l = j * 16 + 8 - blockposition.getZ();
|
||||||
boolean flag = true;
|
boolean flag = true;
|
||||||
|
|
||||||
|
|
Loading…
Add table
Reference in a new issue