Fixed constantly loading players for flair update

This commit is contained in:
Norbi Peti 2016-08-22 16:38:20 +02:00
parent f4eb32c35f
commit 2c08cab6b5

View file

@ -39,6 +39,8 @@ import java.util.ArrayList;
import java.util.Calendar; import java.util.Calendar;
import java.util.Collection; import java.util.Collection;
import java.util.Date; import java.util.Date;
import java.util.HashSet;
import java.util.Set;
import java.util.TimeZone; import java.util.TimeZone;
public class PluginMain extends JavaPlugin { // Translated to Java: 2015.07.15. public class PluginMain extends JavaPlugin { // Translated to Java: 2015.07.15.
@ -51,6 +53,15 @@ public class PluginMain extends JavaPlugin { // Translated to Java: 2015.07.15.
public TownyUniverse TU; public TownyUniverse TU;
public ArrayList<Town> Towns; public ArrayList<Town> Towns;
public ArrayList<Nation> Nations; public ArrayList<Nation> Nations;
/**
* <p>
* This variable is used as a cache for flair state checking when reading the flair thread.
* </p>
* <p>
* It's used because normally it has to load all associated player files everytime to read the filename
* </p>
*/
private Set<String> PlayersWithFlairs = new HashSet<>();
// Fired when plugin is first enabled // Fired when plugin is first enabled
@Override @Override
@ -152,17 +163,21 @@ public class PluginMain extends JavaPlugin { // Translated to Java: 2015.07.15.
else else
ign = ign.substring(start, end); ign = ign.substring(start, end);
ign = ign.trim(); ign = ign.trim();
ChatPlayer mp = ChatPlayer.GetFromName(ign); if (PlayersWithFlairs.contains(ign))
continue;
ChatPlayer mp = ChatPlayer.GetFromName(ign); // Loads player file
if (mp == null) if (mp == null)
continue; continue;
if (!JoinedBefore(mp, 2015, 6, 5)) /*
continue; * if (!JoinedBefore(mp, 2015, 6, 5)) continue;
*/
if (!mp.UserNames.contains(author)) if (!mp.UserNames.contains(author))
mp.UserNames.add(author); mp.UserNames.add(author);
if (mp.FlairState.equals(FlairStates.NoComment)) { if (mp.FlairState.equals(FlairStates.NoComment)) {
mp.FlairState = FlairStates.Commented; mp.FlairState = FlairStates.Commented;
ConfirmUserMessage(mp); ConfirmUserMessage(mp);
} } else
PlayersWithFlairs.add(ign);
try { try {
Thread.sleep(10); Thread.sleep(10);
} catch (InterruptedException ex) { } catch (InterruptedException ex) {
@ -289,14 +304,13 @@ public class PluginMain extends JavaPlugin { // Translated to Java: 2015.07.15.
} }
PluginMain.Instance.getLogger().info("Loading files..."); PluginMain.Instance.getLogger().info("Loading files...");
try { try {
File file = new File("thebuttonmc.yml"); // TODO File file = new File("TBMC/chatsettings.yml"); // TODO
if (file.exists()) { if (file.exists()) {
YamlConfiguration yc = new YamlConfiguration(); YamlConfiguration yc = new YamlConfiguration();
yc.load(file); yc.load(file);
PlayerListener.NotificationSound = yc.getString("notificationsound"); PlayerListener.NotificationSound = yc.getString("notificationsound");
PlayerListener.NotificationPitch = yc.getDouble("notificationpitch"); PlayerListener.NotificationPitch = yc.getDouble("notificationpitch");
AnnounceTime = yc.getInt("announcetime"); // TODO: Move out to AnnounceTime = yc.getInt("announcetime");
// the core
AnnounceMessages.addAll(yc.getStringList("announcements")); AnnounceMessages.addAll(yc.getStringList("announcements"));
PlayerListener.AlphaDeaths = yc.getInt("alphadeaths"); PlayerListener.AlphaDeaths = yc.getInt("alphadeaths");
} }
@ -313,7 +327,7 @@ public class PluginMain extends JavaPlugin { // Translated to Java: 2015.07.15.
public static void SaveFiles() { public static void SaveFiles() {
PluginMain.Instance.getLogger().info("Saving files..."); PluginMain.Instance.getLogger().info("Saving files...");
try { try {
File file = new File("thebuttonmc.yml"); File file = new File("TBMC/chatsettings.yml");
YamlConfiguration yc = new YamlConfiguration(); YamlConfiguration yc = new YamlConfiguration();
yc.set("notificationsound", PlayerListener.NotificationSound); yc.set("notificationsound", PlayerListener.NotificationSound);
yc.set("notificationpitch", PlayerListener.NotificationPitch); yc.set("notificationpitch", PlayerListener.NotificationPitch);