aboutsummaryrefslogtreecommitdiff
path: root/src/main/java/at/hannibal2/skyhanni/data
diff options
context:
space:
mode:
authorhannibal2 <24389977+hannibal002@users.noreply.github.com>2024-08-31 10:20:42 +0200
committerGitHub <noreply@github.com>2024-08-31 10:20:42 +0200
commit96423e4b788e2dd96001dc3bf788b1d542d73ba0 (patch)
tree4de172535b7807b5b8ebc29af6ed98a5d4a3656f /src/main/java/at/hannibal2/skyhanni/data
parentd298d2a04fa4d0cbcb4f03fae84cc2f498e06a63 (diff)
downloadskyhanni-96423e4b788e2dd96001dc3bf788b1d542d73ba0.tar.gz
skyhanni-96423e4b788e2dd96001dc3bf788b1d542d73ba0.tar.bz2
skyhanni-96423e4b788e2dd96001dc3bf788b1d542d73ba0.zip
Backend: /shdebugscoreboard (#2412)
Co-authored-by: hannibal2 <24389977+hannibal00212@users.noreply.github.com>
Diffstat (limited to 'src/main/java/at/hannibal2/skyhanni/data')
-rw-r--r--src/main/java/at/hannibal2/skyhanni/data/ScoreboardData.kt32
1 files changed, 32 insertions, 0 deletions
diff --git a/src/main/java/at/hannibal2/skyhanni/data/ScoreboardData.kt b/src/main/java/at/hannibal2/skyhanni/data/ScoreboardData.kt
index 2287ae358..378fe03c6 100644
--- a/src/main/java/at/hannibal2/skyhanni/data/ScoreboardData.kt
+++ b/src/main/java/at/hannibal2/skyhanni/data/ScoreboardData.kt
@@ -6,7 +6,10 @@ import at.hannibal2.skyhanni.events.RawScoreboardUpdateEvent
import at.hannibal2.skyhanni.events.ScoreboardUpdateEvent
import at.hannibal2.skyhanni.events.minecraft.packet.PacketReceivedEvent
import at.hannibal2.skyhanni.skyhannimodule.SkyHanniModule
+import at.hannibal2.skyhanni.utils.ChatUtils
+import at.hannibal2.skyhanni.utils.SimpleTimeMark
import at.hannibal2.skyhanni.utils.StringUtils.lastColorCode
+import at.hannibal2.skyhanni.utils.TimeUtils.format
import net.minecraft.client.Minecraft
import net.minecraft.network.play.server.S3CPacketUpdateScore
import net.minecraft.network.play.server.S3EPacketTeams
@@ -70,19 +73,41 @@ object ScoreboardData {
if (event.packet is S3CPacketUpdateScore) {
if (event.packet.objectiveName == "update") {
dirty = true
+ monitor()
}
}
if (event.packet is S3EPacketTeams) {
if (event.packet.name.startsWith("team_")) {
dirty = true
+ monitor()
}
}
}
+ private var monitor = false
+ private var lastMonitorState = emptyList<String>()
+ private var lastChangeTime = SimpleTimeMark.farPast()
+
+ private fun monitor() {
+ if (!monitor) return
+ val currentList = fetchScoreboardLines()
+ if (lastMonitorState != currentList) {
+ val time = lastChangeTime.passedSince()
+ lastChangeTime = SimpleTimeMark.now()
+ println("Scoreboard Monitor: (new change after ${time.format(showMilliSeconds = true)})")
+ for (s in currentList) {
+ println("'$s'")
+ }
+ }
+ lastMonitorState = currentList
+ println(" ")
+ }
+
@SubscribeEvent(priority = EventPriority.HIGHEST)
fun onTick(event: LorenzTickEvent) {
if (!dirty) return
dirty = false
+ monitor()
val list = fetchScoreboardLines().reversed()
val semiFormatted = list.map { cleanSB(it) }
@@ -99,6 +124,13 @@ object ScoreboardData {
}
}
+ fun toggleMonitor() {
+ monitor = !monitor
+ val action = if (monitor) "Enabled" else "Disabled"
+ ChatUtils.chat("$action scoreboard monitoring in the console.")
+
+ }
+
private fun cleanSB(scoreboard: String): String {
return scoreboard.toCharArray().filter { it.code in 21..126 || it.code == 167 }.joinToString(separator = "")
}