summaryrefslogtreecommitdiffstats
path: root/Essentials/src/com/earth2me/essentials/EssentialsTimer.java
blob: 4c17fda371724b3f4b5ee5dafad72b90c6ca93cc (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
package com.earth2me.essentials;

import java.util.HashSet;
import java.util.Iterator;
import java.util.LinkedList;
import java.util.Set;
import java.util.UUID;
import java.util.logging.Level;
import net.ess3.api.IEssentials;
import org.bukkit.entity.Player;


public class EssentialsTimer implements Runnable
{
	private final transient IEssentials ess;
	private final transient Set<UUID> onlineUsers = new HashSet<UUID>();
	private transient long lastPoll = System.nanoTime();
	private final LinkedList<Double> history = new LinkedList<Double>();
	private int skip1 = 0;
	private int skip2 = 0;
	private final long maxTime = 10 * 1000000;
	private final long tickInterval = 50;
	
	EssentialsTimer(final IEssentials ess)
	{
		this.ess = ess;
		history.add(20d);
	}
	
	@Override
	public void run()
	{
		final long startTime = System.nanoTime();
		final long currentTime = System.currentTimeMillis();
		long timeSpent = (startTime - lastPoll) / 1000;
		if (timeSpent == 0)
		{
			timeSpent = 1;
		}
		if (history.size() > 10)
		{
			history.remove();
		}
		double tps = tickInterval * 1000000.0 / timeSpent;
		if (tps <= 21)
		{
			history.add(tps);
		}
		lastPoll = startTime;
		int count = 0;
		for (Player player : ess.getServer().getOnlinePlayers())
		{
			count++;
			if (skip1 > 0)
			{
				skip1--;
				continue;
			}
			if (count % 10 == 0)
			{
				if (System.nanoTime() - startTime > maxTime / 2)
				{
					skip1 = count - 1;
					break;
				}
			}
			try
			{
				final User user = ess.getUser(player);
				onlineUsers.add(user.getBase().getUniqueId());
				user.setLastOnlineActivity(currentTime);
				user.checkActivity();
			}
			catch (Exception e)
			{
				ess.getLogger().log(Level.WARNING, "EssentialsTimer Error:", e);
			}
		}
		
		count = 0;
		final Iterator<UUID> iterator = onlineUsers.iterator();
		while (iterator.hasNext())
		{
			count++;
			if (skip2 > 0)
			{
				skip2--;
				continue;
			}
			if (count % 10 == 0)
			{
				if (System.nanoTime() - startTime > maxTime)
				{
					skip2 = count - 1;
					break;
				}
			}
			final User user = ess.getUser(iterator.next());
			if (user.getLastOnlineActivity() < currentTime && user.getLastOnlineActivity() > user.getLastLogout())
			{
				if (!user.isHidden()) {
					user.setLastLogout(user.getLastOnlineActivity());
				}
				iterator.remove();
				continue;
			}
			user.checkMuteTimeout(currentTime);
			user.checkJailTimeout(currentTime);
			user.resetInvulnerabilityAfterTeleport();
		}
	}
	
	public double getAverageTPS()
	{
		double avg = 0;
		for (Double f : history)
		{
			if (f != null)
			{
				avg += f;
			}
		}		
		return avg / history.size();
	}
}