Fix teleport failing right after join. Fixes BUKKIT-5479

Teleporting a player checks to see if the player is disconnected to
try to avoid creating ghost players. The check it uses, however, randomly
fails when the player is in the middle of joining the server. The check
that would work correctly here does not work correctly when the player
actually disconnects. To work around this we add a new flag which is
cleared on the first tick of the new player and assume they are connected
if the flag is set.
This commit is contained in:
Travis Watkins 2014-03-22 19:25:55 -05:00
parent 4873b12890
commit 019a33f50d
3 changed files with 14 additions and 3 deletions

View file

@ -61,6 +61,7 @@ public class EntityPlayer extends EntityHuman implements ICrafting {
public int newTotalExp = 0; public int newTotalExp = 0;
public boolean keepLevel = false; public boolean keepLevel = false;
public double maxHealthCache; public double maxHealthCache;
public boolean joining = true;
// CraftBukkit end // CraftBukkit end
public EntityPlayer(MinecraftServer minecraftserver, WorldServer worldserver, GameProfile gameprofile, PlayerInteractManager playerinteractmanager) { public EntityPlayer(MinecraftServer minecraftserver, WorldServer worldserver, GameProfile gameprofile, PlayerInteractManager playerinteractmanager) {
@ -159,6 +160,12 @@ public class EntityPlayer extends EntityHuman implements ICrafting {
} }
public void h() { public void h() {
// CraftBukkit start
if (this.joining) {
this.joining = false;
}
// CraftBukkit end
this.playerInteractManager.a(); this.playerInteractManager.a();
--this.invulnerableTicks; --this.invulnerableTicks;
if (this.noDamageTicks > 0) { if (this.noDamageTicks > 0) {

View file

@ -1850,7 +1850,7 @@ public class PlayerConnection implements PacketPlayInListener {
// CraftBukkit start - Add "isDisconnected" method // CraftBukkit start - Add "isDisconnected" method
public final boolean isDisconnected() { public final boolean isDisconnected() {
return !NetworkManager.a(this.networkManager).config().isAutoRead(); return !this.player.joining && !NetworkManager.a(this.networkManager).config().isAutoRead();
} }
// CraftBukkit end // CraftBukkit end
} }

View file

@ -83,8 +83,8 @@ public abstract class PlayerList {
s = networkmanager.getSocketAddress().toString(); s = networkmanager.getSocketAddress().toString();
} }
// CraftBukkit - add world to 'logged in' message. // CraftBukkit - Moved message to after join
c.info(entityplayer.getName() + "[" + s + "] logged in with entity id " + entityplayer.getId() + " at ([" + entityplayer.world.worldData.getName() + "] " + entityplayer.locX + ", " + entityplayer.locY + ", " + entityplayer.locZ + ")"); // c.info(entityplayer.getName() + "[" + s + "] logged in with entity id " + entityplayer.getId() + " at (" + entityplayer.locX + ", " + entityplayer.locY + ", " + entityplayer.locZ + ")");
WorldServer worldserver = this.server.getWorldServer(entityplayer.dimension); WorldServer worldserver = this.server.getWorldServer(entityplayer.dimension);
ChunkCoordinates chunkcoordinates = worldserver.getSpawn(); ChunkCoordinates chunkcoordinates = worldserver.getSpawn();
@ -114,6 +114,7 @@ public abstract class PlayerList {
this.sendMessage(chatmessage); this.sendMessage(chatmessage);
// CraftBukkit end*/ // CraftBukkit end*/
this.c(entityplayer); this.c(entityplayer);
worldserver = this.server.getWorldServer(entityplayer.dimension); // CraftBukkit - Update in case join event changed it
playerconnection.a(entityplayer.locX, entityplayer.locY, entityplayer.locZ, entityplayer.yaw, entityplayer.pitch); playerconnection.a(entityplayer.locX, entityplayer.locY, entityplayer.locZ, entityplayer.yaw, entityplayer.pitch);
this.b(entityplayer, worldserver); this.b(entityplayer, worldserver);
if (this.server.getResourcePack().length() > 0) { if (this.server.getResourcePack().length() > 0) {
@ -139,6 +140,9 @@ public abstract class PlayerList {
entity.n = false; entity.n = false;
} }
} }
// CraftBukkit - Moved from above, added world
c.info(entityplayer.getName() + "[" + s + "] logged in with entity id " + entityplayer.getId() + " at ([" + entityplayer.world.worldData.getName() + "] " + entityplayer.locX + ", " + entityplayer.locY + ", " + entityplayer.locZ + ")");
} }
public void a(ScoreboardServer scoreboardserver, EntityPlayer entityplayer) { // CraftBukkit - protected -> public public void a(ScoreboardServer scoreboardserver, EntityPlayer entityplayer) { // CraftBukkit - protected -> public