diff options
-rw-r--r-- | build.gradle.kts | 4 | ||||
-rw-r--r-- | src/main/java/at/hannibal2/skyhanni/mixins/transformers/MixinXPInformation.java | 14 | ||||
-rw-r--r-- | src/main/java/at/hannibal2/skyhanni/utils/CombatUtils.kt | 13 |
3 files changed, 28 insertions, 3 deletions
diff --git a/build.gradle.kts b/build.gradle.kts index 41e1d0322..4b047476a 100644 --- a/build.gradle.kts +++ b/build.gradle.kts @@ -104,7 +104,7 @@ dependencies { exclude(module = "unspecified") isTransitive = false } - devenvMod("com.github.NotEnoughUpdates:NotEnoughUpdates:v2.1.1-pre5:all") { + devenvMod("com.github.NotEnoughUpdates:NotEnoughUpdates:6a661042b0:all") { exclude(module = "unspecified") isTransitive = false } @@ -115,7 +115,7 @@ dependencies { implementation(libs.hotswapagentforge) // testImplementation(kotlin("test")) - testImplementation("com.github.NotEnoughUpdates:NotEnoughUpdates:v2.1.1-pre5:all") { + testImplementation("com.github.NotEnoughUpdates:NotEnoughUpdates:6a661042b0:all") { exclude(module = "unspecified") isTransitive = false } diff --git a/src/main/java/at/hannibal2/skyhanni/mixins/transformers/MixinXPInformation.java b/src/main/java/at/hannibal2/skyhanni/mixins/transformers/MixinXPInformation.java new file mode 100644 index 000000000..16fb774cd --- /dev/null +++ b/src/main/java/at/hannibal2/skyhanni/mixins/transformers/MixinXPInformation.java @@ -0,0 +1,14 @@ +package at.hannibal2.skyhanni.mixins.transformers; + +import org.spongepowered.asm.mixin.Mixin; +import org.spongepowered.asm.mixin.Pseudo; +import org.spongepowered.asm.mixin.gen.Accessor; + +@Pseudo +@Mixin(targets = "io.github.moulberry.notenoughupdates.util.XPInformation$SkillInfo") +public interface MixinXPInformation { + + @Accessor(value = "totalXp") + double getTotalXp(); + +} diff --git a/src/main/java/at/hannibal2/skyhanni/utils/CombatUtils.kt b/src/main/java/at/hannibal2/skyhanni/utils/CombatUtils.kt index 31bfe4416..362654807 100644 --- a/src/main/java/at/hannibal2/skyhanni/utils/CombatUtils.kt +++ b/src/main/java/at/hannibal2/skyhanni/utils/CombatUtils.kt @@ -2,6 +2,7 @@ package at.hannibal2.skyhanni.utils import at.hannibal2.skyhanni.features.combat.ghostcounter.GhostCounter import at.hannibal2.skyhanni.features.combat.ghostcounter.GhostData +import at.hannibal2.skyhanni.mixins.transformers.MixinXPInformation import io.github.moulberry.notenoughupdates.core.util.lerp.LerpUtils import io.github.moulberry.notenoughupdates.util.XPInformation @@ -25,6 +26,16 @@ object CombatUtils { private var gainTimer = 0 var _isKilling = false + private fun getSkillInfo(xpInformation: XPInformation.SkillInfo?): Float { + return try { + val a = xpInformation as? MixinXPInformation + a!!.getTotalXp().toFloat() + } catch (e: Exception) { + val xpInfo = xpInformation ?: return -1f + xpInfo.totalXp + } + } + /** * Taken from NotEnoughUpdates */ @@ -33,7 +44,7 @@ object CombatUtils { xpGainHourLast = xpGainHour skillInfoLast = skillInfo skillInfo = XPInformation.getInstance().getSkillInfo(SKILL_TYPE) ?: return - val totalXp: Float = skillInfo!!.totalXp + val totalXp = getSkillInfo(skillInfo) if (lastTotalXp > 0) { val delta: Float = totalXp - lastTotalXp |