L'historique des calculs d'un joueur est maintenant stocké dans la classe OnlinePlayer

This commit is contained in:
2015-01-25 01:21:13 -05:00
parent a4a138b9dc
commit fc64edebe6
5 changed files with 29 additions and 40 deletions

View File

@@ -1,37 +1,27 @@
package net.mc_pandacraft.java.plugin.pandacraftutils.modules;
import java.util.ArrayList;
import java.util.HashMap;
import java.util.List;
import java.util.Map;
import net.mc_pandacraft.java.plugin.pandacraftutils.PandacraftUtils;
import net.mc_pandacraft.java.plugin.pandacraftutils.players.OnlinePlayer;
import net.mc_pandacraft.java.plugin.pandacraftutils.players.OnlinePlayerManager;
import net.mc_pandacraft.java.util.JArithmeticInterpreter;
import net.mc_pandacraft.java.util.StringUtil;
import org.bukkit.ChatColor;
import org.bukkit.entity.Player;
import org.bukkit.event.EventHandler;
import org.bukkit.event.EventPriority;
import org.bukkit.event.Listener;
import org.bukkit.event.player.AsyncPlayerChatEvent;
import org.bukkit.event.player.PlayerJoinEvent;
import org.bukkit.event.player.PlayerQuitEvent;
public class CalculatorManager implements Listener {
private PandacraftUtils plugin = PandacraftUtils.getInstance();
private Map<Player, List<HistoryElement>> history = new HashMap<Player, List<HistoryElement>>();
public CalculatorManager() {
plugin.getServer().getPluginManager().registerEvents(this, plugin);
// analyse des joueurs déjà en ligne (/reload)
for (Player p : plugin.getServer().getOnlinePlayers())
onPlayerJoin(new PlayerJoinEvent(p, "")); // simule l'évènement d'arrivé d'un joueur, pour le rajouter
}
@@ -44,16 +34,19 @@ public class CalculatorManager implements Listener {
if (!message.startsWith("="))
return;
OnlinePlayer op = OnlinePlayerManager.getInstance().get(event.getPlayer());
List<HistoryElement> history = op.getCalculator_history();
if (message.length() == 1)
{ // affichage de l'historique
event.getPlayer().sendMessage(ChatColor.GRAY+"Historique d'utilisation de la calculatrice");
int i = history.get(event.getPlayer()).size();
for(HistoryElement el : history.get(event.getPlayer()))
int i = history.size();
for(HistoryElement el : history)
{
event.getPlayer().sendMessage(ChatColor.GRAY+"res"+i+ChatColor.RESET+" : "+ChatColor.GRAY+el.expression+ChatColor.RESET+"="+ChatColor.GRAY+el.value);
i--;
}
if (history.get(event.getPlayer()).size() == 0)
if (history.size() == 0)
{
event.getPlayer().sendMessage(ChatColor.RED+"Utilisez le symbole "+ChatColor.GRAY+"="+ChatColor.RED+" dans le chat pour faire un calcul mathématique");
}
@@ -73,9 +66,7 @@ public class CalculatorManager implements Listener {
calcul.value = StringUtil.formatDouble(JArithmeticInterpreter.getResultFromExpression(message, expression));
calcul.expression = expression.toString();
history.get(event.getPlayer()).add(calcul);
if (history.get(event.getPlayer()).size() > 5)
history.get(event.getPlayer()).remove(0);
op.addToCalculatorHistory(calcul);
event.getPlayer().sendMessage(ChatColor.GRAY+calcul.expression+ChatColor.RESET+"="+ChatColor.GRAY+calcul.value);
@@ -94,26 +85,8 @@ public class CalculatorManager implements Listener {
}
@EventHandler
public void onPlayerJoin(PlayerJoinEvent event)
{
history.put(event.getPlayer(), new ArrayList<HistoryElement>());
}
@EventHandler
public void onPlayerQuit(PlayerQuitEvent event)
{
history.remove(event.getPlayer());
}
private class HistoryElement
public class HistoryElement
{
public String expression;
public String value;