[Bleeding] Only do unload-all on tick when last player leaves. Fixes BUKKIT-1060

Dieser Commit ist enthalten in:
Mike Primm 2012-03-08 00:58:30 -06:00 committet von EvilSeph
Ursprung 0ba2d285f0
Commit 1e06e150b6

Datei anzeigen

@ -12,6 +12,7 @@ public class PlayerManager {
private int e;
private int f;
private final int[][] g = new int[][] { { 1, 0}, { 0, 1}, { -1, 0}, { 0, -1}};
private boolean wasNotEmpty; // CraftBukkit
public PlayerManager(MinecraftServer minecraftserver, int i, int j) {
if (j > 15) {
@ -36,13 +37,19 @@ public class PlayerManager {
this.c.clear();
if (this.managedPlayers.isEmpty()) {
if (!wasNotEmpty) return; // CraftBukkit - only do unload when we go from non-empty to empty
WorldServer worldserver = this.server.getWorldServer(this.e);
WorldProvider worldprovider = worldserver.worldProvider;
if (!worldprovider.c()) {
worldserver.chunkProviderServer.c();
}
// CraftBukkit start
wasNotEmpty = false;
} else {
wasNotEmpty = true;
}
// CraftBukkit end
}
private PlayerInstance a(int i, int j, boolean flag) {