mirror of
https://github.com/PaperMC/Paper.git
synced 2025-01-10 10:17:38 +01:00
No teleporting people back into the server. Fixes BUKKIT-2298
Stale player references will add a player back into the world when teleporting them, causing a cascade of issues relating to ghost entities and servers failing to stop. By: Wesley Wolfe <weswolf@aol.com>
This commit is contained in:
parent
65f1456adc
commit
35a4233999
@ -345,7 +345,8 @@ public class CraftPlayer extends CraftHumanEntity implements Player {
|
||||
|
||||
@Override
|
||||
public boolean teleport(Location location, PlayerTeleportEvent.TeleportCause cause) {
|
||||
if (getHandle().netServerHandler == null) return false;
|
||||
EntityPlayer entity = getHandle();
|
||||
if (entity.netServerHandler == null || entity.netServerHandler.disconnected) return false;
|
||||
|
||||
// From = Players current Location
|
||||
Location from = this.getLocation();
|
||||
@ -365,8 +366,6 @@ public class CraftPlayer extends CraftHumanEntity implements Player {
|
||||
// Grab the To and From World Handles.
|
||||
WorldServer fromWorld = ((CraftWorld) from.getWorld()).getHandle();
|
||||
WorldServer toWorld = ((CraftWorld) to.getWorld()).getHandle();
|
||||
// Grab the EntityPlayer
|
||||
EntityPlayer entity = getHandle();
|
||||
|
||||
// Check if the fromWorld and toWorld are the same.
|
||||
if (fromWorld == toWorld) {
|
||||
|
Loading…
Reference in New Issue
Block a user