blob: 95ce8823fc28510f8d52201d9551346e97bf9fa4 (
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
|
package at.hannibal2.skyhanni.events
import at.hannibal2.skyhanni.SkyHanniMod
import at.hannibal2.skyhanni.utils.LorenzUtils
import at.hannibal2.skyhanni.utils.LorenzUtils.sorted
import net.minecraftforge.common.MinecraftForge
import net.minecraftforge.fml.common.eventhandler.Event
abstract class LorenzEvent : Event() {
companion object {
val map = mutableMapOf<String, Long>()
var lastPrint = 0L
}
private val eventName by lazy {
this::class.simpleName
}
fun postAndCatch(): Boolean {
return runCatching {
if (!SkyHanniMod.feature.dev.printEventTimings) {
return MinecraftForge.EVENT_BUS.post(this)
}
val start = System.currentTimeMillis()
val result = MinecraftForge.EVENT_BUS.post(this)
val end = System.currentTimeMillis() - start
eventName?.let { map.put(it, end + map.getOrDefault(it, 0)) }
if (System.currentTimeMillis() > lastPrint + 10_000) {
lastPrint = System.currentTimeMillis()
println(" ")
println("Event Timings!")
for (entry in map.sorted()) {
println(entry.key + ": " + entry.value + " ms")
}
println(" ")
map.clear()
}
result
}.onFailure {
it.printStackTrace()
LorenzUtils.chat("§cSkyHanni caught and logged an ${it::class.simpleName ?: "error"} at ${eventName}.")
}.getOrDefault(isCanceled)
}
}
|