From b8f742a5889d8aa5bad08fa49f2aa10fde682e5c Mon Sep 17 00:00:00 2001 From: t00thpick1 Date: Sun, 7 Dec 2014 14:52:56 -0500 Subject: [PATCH] Remove players from internal map immediately. Should resolve #117 --- .../factions/util/AutoLeaveProcessTask.java | 3 ++- .../factions/zcore/persist/json/JSONFPlayer.java | 10 +++------- 2 files changed, 5 insertions(+), 8 deletions(-) diff --git a/src/main/java/com/massivecraft/factions/util/AutoLeaveProcessTask.java b/src/main/java/com/massivecraft/factions/util/AutoLeaveProcessTask.java index 14cce15e..3ee8d134 100644 --- a/src/main/java/com/massivecraft/factions/util/AutoLeaveProcessTask.java +++ b/src/main/java/com/massivecraft/factions/util/AutoLeaveProcessTask.java @@ -2,6 +2,7 @@ package com.massivecraft.factions.util; import com.massivecraft.factions.*; import com.massivecraft.factions.struct.Role; + import org.bukkit.scheduler.BukkitRunnable; import java.util.ArrayList; @@ -15,7 +16,7 @@ public class AutoLeaveProcessTask extends BukkitRunnable { private transient double toleranceMillis; public AutoLeaveProcessTask() { - ArrayList fplayers = new ArrayList(FPlayers.getInstance().getAllFPlayers()); + ArrayList fplayers = (ArrayList) FPlayers.getInstance().getAllFPlayers(); this.iterator = fplayers.listIterator(); this.toleranceMillis = Conf.autoLeaveAfterDaysOfInactivity * 24 * 60 * 60 * 1000; this.readyToGo = true; diff --git a/src/main/java/com/massivecraft/factions/zcore/persist/json/JSONFPlayer.java b/src/main/java/com/massivecraft/factions/zcore/persist/json/JSONFPlayer.java index 6b642103..71d451d2 100644 --- a/src/main/java/com/massivecraft/factions/zcore/persist/json/JSONFPlayer.java +++ b/src/main/java/com/massivecraft/factions/zcore/persist/json/JSONFPlayer.java @@ -1,32 +1,28 @@ package com.massivecraft.factions.zcore.persist.json; import com.massivecraft.factions.Conf; +import com.massivecraft.factions.FPlayers; import com.massivecraft.factions.zcore.persist.MemoryFPlayer; public class JSONFPlayer extends MemoryFPlayer { - private transient boolean remove = false; public JSONFPlayer(MemoryFPlayer arg0) { super(arg0); } - public JSONFPlayer() { - remove = false; - } - public JSONFPlayer(String id) { super(id); } @Override public void remove() { - remove = true; + ((JSONFPlayers) FPlayers.getInstance()).fPlayers.remove(getId()); } public boolean shouldBeSaved() { if (!this.hasFaction() && (this.getPowerRounded() == this.getPowerMaxRounded() || this.getPowerRounded() == (int) Math.round(Conf.powerPlayerStarting))) { return false; } - return !remove; + return true; } }