NoCheatPlus/src/fr/neatmonster/nocheatplus/metrics/MetricsData.java

91 lines
3.1 KiB
Java
Raw Normal View History

2012-08-20 19:40:00 +02:00
package fr.neatmonster.nocheatplus.metrics;
import java.util.HashMap;
import java.util.Map;
import fr.neatmonster.nocheatplus.checks.CheckType;
/*
* M"""""`'"""`YM dP oo M""""""'YMM dP
* M mm. mm. M 88 M mmmm. `M 88
* M MMM MMM M .d8888b. d8888P 88d888b. dP .d8888b. .d8888b. M MMMMM M .d8888b. d8888P .d8888b.
* M MMM MMM M 88ooood8 88 88' `88 88 88' `"" Y8ooooo. M MMMMM M 88' `88 88 88' `88
* M MMM MMM M 88. ... 88 88 88 88. ... 88 M MMMM' .M 88. .88 88 88. .88
* M MMM MMM M `88888P' dP dP dP `88888P' `88888P' M .MM `88888P8 dP `88888P8
* MMMMMMMMMMMMMM MMMMMMMMMMM
*/
/**
2012-08-24 22:02:38 +02:00
* This class is used to store the data that will be sent to Metrics later.
2012-08-20 19:40:00 +02:00
*/
public class MetricsData {
2012-08-24 22:02:38 +02:00
/** Is data collecting enabled? */
private static boolean enabled = false;
2012-08-20 19:40:00 +02:00
2012-08-24 22:02:38 +02:00
/** The map containing the number of fails per check. */
private static final Map<CheckType, Integer> checksFailed = new HashMap<CheckType, Integer>();
2012-08-20 19:40:00 +02:00
2012-08-24 22:02:38 +02:00
/** The map containing the number of seconds per number of ticks this seconds contain. */
private static final Map<Integer, Integer> ticksNumbers = new HashMap<Integer, Integer>();
2012-08-20 19:40:00 +02:00
/**
2012-08-24 22:02:38 +02:00
* Adds a failed check to the specified check type.
2012-08-20 19:40:00 +02:00
*
* @param type
2012-08-24 22:02:38 +02:00
* the check type
2012-08-20 19:40:00 +02:00
*/
2012-08-24 22:02:38 +02:00
public static void addFailed(final CheckType type) {
if (enabled && type.getParent() != null)
2012-08-24 22:02:38 +02:00
checksFailed.put(type, checksFailed.get(type) + 1);
2012-08-20 19:40:00 +02:00
}
/**
2012-08-24 22:02:38 +02:00
* Adds a seconds to the number of ticks it has contained.
2012-08-20 20:09:23 +02:00
*
* @param ticks
2012-08-24 22:02:38 +02:00
* the ticks number
2012-08-20 20:09:23 +02:00
*/
public static void addTicks(final int ticks) {
if (enabled)
2012-08-24 22:02:38 +02:00
ticksNumbers.put(ticks, ticksNumbers.get(ticks) + 1);
2012-08-20 19:40:00 +02:00
}
/**
2012-08-24 22:02:38 +02:00
* Gets the number of failed checks for the specified check type.
2012-08-20 19:40:00 +02:00
*
* @param type
2012-08-24 22:02:38 +02:00
* the check type
2012-08-20 20:09:23 +02:00
* @return the failed
2012-08-20 19:40:00 +02:00
*/
public static int getFailed(final CheckType type) {
2012-08-24 22:02:38 +02:00
final int failed = checksFailed.get(type);
checksFailed.put(type, 0);
return failed;
2012-08-20 20:09:23 +02:00
}
/**
2012-08-24 22:02:38 +02:00
* Gets the number of seconds which have contained the specified number of ticks.
2012-08-20 20:09:23 +02:00
*
* @param ticks
2012-08-24 22:02:38 +02:00
* the ticks number
* @return the ticks
2012-08-20 19:40:00 +02:00
*/
2012-08-24 22:02:38 +02:00
public static int getTicks(final int ticks) {
final int number = ticksNumbers.get(ticks);
ticksNumbers.put(ticks, 0);
return number;
2012-08-20 19:40:00 +02:00
}
2012-08-20 20:09:23 +02:00
/**
* Initialize the class.
*/
public static void initialize() {
2012-08-24 22:02:38 +02:00
enabled = true;
for (final CheckType type : CheckType.values())
if (type.getParent() != null)
checksFailed.put(type, 0);
for (int ticks = 0; ticks < 21; ticks++)
ticksNumbers.put(ticks, 0);
2012-08-20 20:09:23 +02:00
}
2012-08-20 19:40:00 +02:00
}