diff options
Diffstat (limited to 'src/main/java/at/hannibal2/skyhanni')
14 files changed, 93 insertions, 72 deletions
diff --git a/src/main/java/at/hannibal2/skyhanni/config/storage/PlayerSpecificStorage.java b/src/main/java/at/hannibal2/skyhanni/config/storage/PlayerSpecificStorage.java index a03928745..171cb82b1 100644 --- a/src/main/java/at/hannibal2/skyhanni/config/storage/PlayerSpecificStorage.java +++ b/src/main/java/at/hannibal2/skyhanni/config/storage/PlayerSpecificStorage.java @@ -2,7 +2,9 @@ package at.hannibal2.skyhanni.config.storage; import at.hannibal2.skyhanni.features.bingo.card.goals.BingoGoal; import at.hannibal2.skyhanni.features.fame.UpgradeReminder; +import at.hannibal2.skyhanni.utils.GenericWrapper; import at.hannibal2.skyhanni.utils.NEUInternalName; +import at.hannibal2.skyhanni.utils.SimpleTimeMark; import com.google.gson.annotations.Expose; import java.util.ArrayList; @@ -24,7 +26,7 @@ public class PlayerSpecificStorage { public Integer gardenCommunityUpgrade = -1; @Expose - public long nextCityProjectParticipationTime = 0L; + public SimpleTimeMark nextCityProjectParticipationTime = GenericWrapper.getSimpleTimeMark(SimpleTimeMark.farPast()).getIt(); @Expose public UpgradeReminder.CommunityShopUpgrade communityShopAccountUpgrade = null; diff --git a/src/main/java/at/hannibal2/skyhanni/config/storage/ProfileSpecificStorage.java b/src/main/java/at/hannibal2/skyhanni/config/storage/ProfileSpecificStorage.java index bc25da446..9d0ca44f9 100644 --- a/src/main/java/at/hannibal2/skyhanni/config/storage/ProfileSpecificStorage.java +++ b/src/main/java/at/hannibal2/skyhanni/config/storage/ProfileSpecificStorage.java @@ -35,6 +35,7 @@ import at.hannibal2.skyhanni.features.rift.area.westvillage.VerminTracker; import at.hannibal2.skyhanni.features.rift.area.westvillage.kloon.KloonTerminal; import at.hannibal2.skyhanni.features.skillprogress.SkillType; import at.hannibal2.skyhanni.features.slayer.SlayerProfitTracker; +import at.hannibal2.skyhanni.utils.GenericWrapper; import at.hannibal2.skyhanni.utils.LorenzVec; import at.hannibal2.skyhanni.utils.NEUInternalName; import at.hannibal2.skyhanni.utils.SimpleTimeMark; @@ -50,6 +51,10 @@ import java.util.Set; public class ProfileSpecificStorage { + private static SimpleTimeMark SimpleTimeMarkFarPast() { + return GenericWrapper.getSimpleTimeMark(SimpleTimeMark.farPast()).getIt(); + } + @Expose public String currentPet = ""; @@ -85,10 +90,10 @@ public class ProfileSpecificStorage { public int timeTowerLevel = 0; @Expose - public long currentTimeTowerEnds = 0; + public SimpleTimeMark currentTimeTowerEnds = SimpleTimeMarkFarPast(); @Expose - public long nextTimeTower = 0; + public SimpleTimeMark nextTimeTower = SimpleTimeMarkFarPast(); @Expose public int currentTimeTowerUses = -1; @@ -103,20 +108,21 @@ public class ProfileSpecificStorage { public boolean hasMuRabbit = false; @Expose - public long bestUpgradeAvailableAt = 0; + public SimpleTimeMark bestUpgradeAvailableAt = SimpleTimeMarkFarPast(); @Expose public long bestUpgradeCost = 0; @Expose - public long lastDataSave = 0; + public SimpleTimeMark lastDataSave = SimpleTimeMarkFarPast(); @Expose public PositionChange positionChange = new PositionChange(); public static class PositionChange { @Expose - public Long lastTime = null; + @Nullable + public SimpleTimeMark lastTime = null; @Expose public int lastPosition = -1; @@ -183,7 +189,8 @@ public class ProfileSpecificStorage { public int bitsAvailable = -1; @Expose - public Long boosterCookieExpiryTime = null; + @Nullable + public SimpleTimeMark boosterCookieExpiryTime = null; } @Expose @@ -194,6 +201,7 @@ public class ProfileSpecificStorage { @Expose public String displayName = ""; + // TODO use SimpleTimeMark @Expose public long lastClicked = -1; @@ -212,7 +220,8 @@ public class ProfileSpecificStorage { public static class BeaconPowerStorage { @Expose - public Long beaconPowerExpiryTime = null; + @Nullable + public SimpleTimeMark beaconPowerExpiryTime = null; @Expose public String boostedStat = null; @@ -267,16 +276,16 @@ public class ProfileSpecificStorage { public DicerRngDropTracker.Data dicerDropTracker = new DicerRngDropTracker.Data(); @Expose - public long informedAboutLowMatter = 0; + public SimpleTimeMark informedAboutLowMatter = SimpleTimeMarkFarPast(); @Expose - public long informedAboutLowFuel = 0; + public SimpleTimeMark informedAboutLowFuel = SimpleTimeMarkFarPast(); @Expose public long visitorInterval = 15 * 60_000L; @Expose - public long nextSixthVisitorArrival = 0; + public SimpleTimeMark nextSixthVisitorArrival = SimpleTimeMarkFarPast(); @Expose public ArmorDropTracker.Data armorDropTracker = new ArmorDropTracker.Data(); @@ -388,10 +397,10 @@ public class ProfileSpecificStorage { } @Expose - public long composterEmptyTime = 0; + public SimpleTimeMark composterEmptyTime = SimpleTimeMarkFarPast(); @Expose - public long lastComposterEmptyWarningTime = 0; + public SimpleTimeMark lastComposterEmptyWarningTime = SimpleTimeMarkFarPast(); @Expose public GardenStorage.FarmingWeightConfig farmingWeight = new GardenStorage.FarmingWeightConfig(); diff --git a/src/main/java/at/hannibal2/skyhanni/data/BitsAPI.kt b/src/main/java/at/hannibal2/skyhanni/data/BitsAPI.kt index 53b80ec25..0077a1dac 100644 --- a/src/main/java/at/hannibal2/skyhanni/data/BitsAPI.kt +++ b/src/main/java/at/hannibal2/skyhanni/data/BitsAPI.kt @@ -17,7 +17,6 @@ import at.hannibal2.skyhanni.utils.RegexUtils.matchFirst import at.hannibal2.skyhanni.utils.RegexUtils.matchMatcher import at.hannibal2.skyhanni.utils.RegexUtils.matches import at.hannibal2.skyhanni.utils.SimpleTimeMark -import at.hannibal2.skyhanni.utils.SimpleTimeMark.Companion.asTimeMark import at.hannibal2.skyhanni.utils.StringUtils.removeResets import at.hannibal2.skyhanni.utils.StringUtils.trimWhiteSpace import at.hannibal2.skyhanni.utils.TimeUtils @@ -49,9 +48,9 @@ object BitsAPI { } var cookieBuffTime: SimpleTimeMark? - get() = profileStorage?.boosterCookieExpiryTime?.asTimeMark() + get() = profileStorage?.boosterCookieExpiryTime private set(value) { - profileStorage?.boosterCookieExpiryTime = value?.toMillis() + profileStorage?.boosterCookieExpiryTime = value } private const val defaultcookiebits = 4800 @@ -308,7 +307,9 @@ object BitsAPI { fun hasCookieBuff() = cookieBuffTime?.isInFuture() ?: false - private fun sendBitsGainEvent(difference: Int) = BitsUpdateEvent.BitsGain(bits, bitsAvailable, difference).postAndCatch() + private fun sendBitsGainEvent(difference: Int) = + BitsUpdateEvent.BitsGain(bits, bitsAvailable, difference).postAndCatch() + private fun sendBitsSpentEvent() = BitsUpdateEvent.BitsSpent(bits, bitsAvailable).postAndCatch() private fun sendBitsAvailableGainedEvent() = BitsUpdateEvent.BitsAvailableGained(bits, bitsAvailable).postAndCatch() diff --git a/src/main/java/at/hannibal2/skyhanni/features/fame/CityProjectFeatures.kt b/src/main/java/at/hannibal2/skyhanni/features/fame/CityProjectFeatures.kt index 88d9f52a8..fed11dac0 100644 --- a/src/main/java/at/hannibal2/skyhanni/features/fame/CityProjectFeatures.kt +++ b/src/main/java/at/hannibal2/skyhanni/features/fame/CityProjectFeatures.kt @@ -73,8 +73,8 @@ object CityProjectFeatures { if (LorenzUtils.skyBlockArea == "Community Center") return - if (playerSpecific.nextCityProjectParticipationTime == 0L) return - if (System.currentTimeMillis() <= playerSpecific.nextCityProjectParticipationTime) return + if (playerSpecific.nextCityProjectParticipationTime.isFarPast()) return + if (playerSpecific.nextCityProjectParticipationTime.isInFuture()) return if (lastReminderSend.passedSince() < 30.seconds) return lastReminderSend = SimpleTimeMark.now() @@ -131,7 +131,7 @@ object CityProjectFeatures { if (item.name != "§eContribute this component!") continue nextTime = now } - ProfileStorageData.playerSpecific?.nextCityProjectParticipationTime = nextTime.toMillis() + ProfileStorageData.playerSpecific?.nextCityProjectParticipationTime = nextTime } } diff --git a/src/main/java/at/hannibal2/skyhanni/features/garden/composter/ComposterDisplay.kt b/src/main/java/at/hannibal2/skyhanni/features/garden/composter/ComposterDisplay.kt index 97e5926ba..a9977f809 100644 --- a/src/main/java/at/hannibal2/skyhanni/features/garden/composter/ComposterDisplay.kt +++ b/src/main/java/at/hannibal2/skyhanni/features/garden/composter/ComposterDisplay.kt @@ -17,11 +17,13 @@ import at.hannibal2.skyhanni.utils.NEUInternalName.Companion.asInternalName import at.hannibal2.skyhanni.utils.NEUItems.getItemStack import at.hannibal2.skyhanni.utils.RegexUtils.matchMatcher import at.hannibal2.skyhanni.utils.RenderUtils.renderStringsAndItems -import at.hannibal2.skyhanni.utils.TimeUtils +import at.hannibal2.skyhanni.utils.SimpleTimeMark +import at.hannibal2.skyhanni.utils.SimpleTimeMark.Companion.fromNow import at.hannibal2.skyhanni.utils.TimeUtils.format import net.minecraftforge.fml.common.eventhandler.SubscribeEvent import java.util.Collections import kotlin.time.Duration +import kotlin.time.Duration.Companion.minutes import kotlin.time.Duration.Companion.seconds @SkyHanniModule @@ -84,7 +86,7 @@ object ComposterDisplay { private fun addComposterEmptyTime(emptyTime: Duration?): List<Any> { return if (emptyTime != null) { - GardenAPI.storage?.composterEmptyTime = System.currentTimeMillis() + emptyTime.inWholeMilliseconds + GardenAPI.storage?.composterEmptyTime = emptyTime.fromNow() val format = emptyTime.format() listOf(bucket, "§b$format") } else { @@ -127,22 +129,21 @@ object ComposterDisplay { val storage = storage ?: return - if (ComposterAPI.getOrganicMatter() <= config.notifyLow.organicMatter && System.currentTimeMillis() >= storage.informedAboutLowMatter) { + if (ComposterAPI.getOrganicMatter() <= config.notifyLow.organicMatter && storage.informedAboutLowMatter.isInPast()) { if (config.notifyLow.title) { LorenzUtils.sendTitle("§cYour Organic Matter is low", 4.seconds) } ChatUtils.chat("§cYour Organic Matter is low!") - storage.informedAboutLowMatter = System.currentTimeMillis() + 60_000 * 5 + storage.informedAboutLowMatter = 5.0.minutes.fromNow() } - if (ComposterAPI.getFuel() <= config.notifyLow.fuel && - System.currentTimeMillis() >= storage.informedAboutLowFuel + if (ComposterAPI.getFuel() <= config.notifyLow.fuel && storage.informedAboutLowFuel.isInPast() ) { if (config.notifyLow.title) { LorenzUtils.sendTitle("§cYour Fuel is low", 4.seconds) } ChatUtils.chat("§cYour Fuel is low!") - storage.informedAboutLowFuel = System.currentTimeMillis() + 60_000 * 5 + storage.informedAboutLowFuel = 5.0.minutes.fromNow() } } @@ -159,13 +160,13 @@ object ComposterDisplay { private fun checkWarningsAndOutsideGarden() { val format = GardenAPI.storage?.let { - if (it.composterEmptyTime != 0L) { - val duration = it.composterEmptyTime - System.currentTimeMillis() - if (duration > 0) { - if (duration < 1000 * 60 * 20) { + if (!it.composterEmptyTime.isFarPast()) { + val duration = it.composterEmptyTime.timeUntil() + if (duration > 0.0.seconds) { + if (duration < 20.0.minutes) { warn("Your composter in the garden is almost empty!") } - TimeUtils.formatDuration(duration, maxUnits = 3) + duration.format(maxUnits = 3) } else { warn("Your composter is empty!") "§cComposter is empty!" @@ -187,8 +188,8 @@ object ComposterDisplay { if (ReminderUtils.isBusy()) return - if (System.currentTimeMillis() < storage.lastComposterEmptyWarningTime + 1000 * 60 * 2) return - storage.lastComposterEmptyWarningTime = System.currentTimeMillis() + if (storage.lastComposterEmptyWarningTime.passedSince() >= 2.0.minutes) return + storage.lastComposterEmptyWarningTime = SimpleTimeMark.now() if (IslandType.GARDEN.isInIsland()) { ChatUtils.chat(warningMessage) } else { diff --git a/src/main/java/at/hannibal2/skyhanni/features/garden/visitor/GardenVisitorTimer.kt b/src/main/java/at/hannibal2/skyhanni/features/garden/visitor/GardenVisitorTimer.kt index ec3622aa3..3a69f2ece 100644 --- a/src/main/java/at/hannibal2/skyhanni/features/garden/visitor/GardenVisitorTimer.kt +++ b/src/main/java/at/hannibal2/skyhanni/features/garden/visitor/GardenVisitorTimer.kt @@ -15,7 +15,6 @@ import at.hannibal2.skyhanni.utils.LorenzUtils import at.hannibal2.skyhanni.utils.RegexUtils.matchFirst import at.hannibal2.skyhanni.utils.RenderUtils.renderString import at.hannibal2.skyhanni.utils.SimpleTimeMark -import at.hannibal2.skyhanni.utils.SimpleTimeMark.Companion.asTimeMark import at.hannibal2.skyhanni.utils.SoundUtils import at.hannibal2.skyhanni.utils.StringUtils.removeColor import at.hannibal2.skyhanni.utils.TabListData @@ -120,7 +119,7 @@ object GardenVisitorTimer { millis = sixthVisitorArrivalTime.timeUntil() val nextSixthVisitorArrival = SimpleTimeMark.now() + millis + (visitorInterval * (5 - visitorsAmount)) - GardenAPI.storage?.nextSixthVisitorArrival = nextSixthVisitorArrival.toMillis() + GardenAPI.storage?.nextSixthVisitorArrival = nextSixthVisitorArrival if (isSixthVisitorEnabled() && millis.isNegative()) { visitorsAmount++ if (!sixthVisitorReady) { @@ -183,9 +182,8 @@ object GardenVisitorTimer { fun onWorldChange(event: LorenzWorldChangeEvent) { lastVisitors = -1 GardenAPI.storage?.nextSixthVisitorArrival?.let { - val badTime = Duration.INFINITE.inWholeMilliseconds - if (it != badTime && it != -9223370336633802065) { - sixthVisitorArrivalTime = it.asTimeMark() + if (it.isFarFuture() && it.toMillis() != -9223370336633802065) { + sixthVisitorArrivalTime = it } } sixthVisitorReady = false diff --git a/src/main/java/at/hannibal2/skyhanni/features/gui/BeaconPower.kt b/src/main/java/at/hannibal2/skyhanni/features/gui/BeaconPower.kt index 60ed3ed66..0eb596afc 100644 --- a/src/main/java/at/hannibal2/skyhanni/features/gui/BeaconPower.kt +++ b/src/main/java/at/hannibal2/skyhanni/features/gui/BeaconPower.kt @@ -12,7 +12,6 @@ import at.hannibal2.skyhanni.utils.RegexUtils.matchMatcher import at.hannibal2.skyhanni.utils.RegexUtils.matches import at.hannibal2.skyhanni.utils.RenderUtils.renderString import at.hannibal2.skyhanni.utils.SimpleTimeMark -import at.hannibal2.skyhanni.utils.SimpleTimeMark.Companion.asTimeMark import at.hannibal2.skyhanni.utils.TimeUtils import at.hannibal2.skyhanni.utils.TimeUtils.format import at.hannibal2.skyhanni.utils.repopatterns.RepoPattern @@ -45,9 +44,9 @@ object BeaconPower { ) private var expiryTime: SimpleTimeMark - get() = storage?.beaconPowerExpiryTime?.asTimeMark() ?: SimpleTimeMark.farPast() + get() = storage?.beaconPowerExpiryTime ?: SimpleTimeMark.farPast() set(value) { - storage?.beaconPowerExpiryTime = value.toMillis() + storage?.beaconPowerExpiryTime = value } private var stat: String? @@ -118,6 +117,5 @@ object BeaconPower { } } - private fun isEnabled() = LorenzUtils.inSkyBlock && config.beaconPower } diff --git a/src/main/java/at/hannibal2/skyhanni/features/inventory/chocolatefactory/ChocolateAmount.kt b/src/main/java/at/hannibal2/skyhanni/features/inventory/chocolatefactory/ChocolateAmount.kt index 45fbd65de..00e8870d2 100644 --- a/src/main/java/at/hannibal2/skyhanni/features/inventory/chocolatefactory/ChocolateAmount.kt +++ b/src/main/java/at/hannibal2/skyhanni/features/inventory/chocolatefactory/ChocolateAmount.kt @@ -26,13 +26,13 @@ enum class ChocolateAmount(val chocolate: () -> Long) { fun timeUntilGoal(goal: Long): Duration { val profileStorage = profileStorage ?: return Duration.ZERO - val updatedAgo = SimpleTimeMark(profileStorage.lastDataSave).passedSince().inWholeSeconds + val updatedAgo = profileStorage.lastDataSave.passedSince().inWholeSeconds return ChocolateFactoryAPI.timeUntilNeed(goal - chocolate()) - updatedAgo.seconds } companion object { fun chocolateSinceUpdate(): Long { - val lastUpdate = SimpleTimeMark(profileStorage?.lastDataSave ?: return 0) + val lastUpdate = profileStorage?.lastDataSave ?: return 0 val currentTime = SimpleTimeMark.now() val secondsSinceUpdate = (currentTime - lastUpdate).inWholeSeconds @@ -77,9 +77,9 @@ enum class ChocolateAmount(val chocolate: () -> Long) { private fun updateBestUpgrade() { profileStorage?.let { - if (it.bestUpgradeAvailableAt == 0L || it.bestUpgradeCost == 0L) return + if (it.bestUpgradeAvailableAt.isFarPast() || it.bestUpgradeCost == 0L) return val canAffordAt = SimpleTimeMark.now() + CURRENT.timeUntilGoal(it.bestUpgradeCost) - it.bestUpgradeAvailableAt = canAffordAt.toMillis() + it.bestUpgradeAvailableAt = canAffordAt } } } diff --git a/src/main/java/at/hannibal2/skyhanni/features/inventory/chocolatefactory/ChocolateFactoryDataLoader.kt b/src/main/java/at/hannibal2/skyhanni/features/inventory/chocolatefactory/ChocolateFactoryDataLoader.kt index ff2b3276a..a0c177abb 100644 --- a/src/main/java/at/hannibal2/skyhanni/features/inventory/chocolatefactory/ChocolateFactoryDataLoader.kt +++ b/src/main/java/at/hannibal2/skyhanni/features/inventory/chocolatefactory/ChocolateFactoryDataLoader.kt @@ -180,7 +180,7 @@ object ChocolateFactoryDataLoader { profileStorage.rawChocPerSecond = (ChocolateFactoryAPI.chocolatePerSecond / profileStorage.chocolateMultiplier + .01).toInt() - profileStorage.lastDataSave = SimpleTimeMark.now().toMillis() + profileStorage.lastDataSave = SimpleTimeMark.now() ChocolateFactoryStats.updateDisplay() @@ -287,9 +287,9 @@ object ChocolateFactoryDataLoader { val activeDuration = TimeUtils.getDuration(formattedGroup) val activeUntil = SimpleTimeMark.now() + activeDuration - profileStorage.currentTimeTowerEnds = activeUntil.toMillis() + profileStorage.currentTimeTowerEnds = activeUntil } else { - profileStorage.currentTimeTowerEnds = 0 + profileStorage.currentTimeTowerEnds = SimpleTimeMark.farPast() } } timeTowerRechargePattern.matchMatcher(line) { @@ -298,7 +298,7 @@ object ChocolateFactoryDataLoader { val timeUntilTower = TimeUtils.getDuration(formattedGroup) val nextTimeTower = SimpleTimeMark.now() + timeUntilTower - profileStorage.nextTimeTower = nextTimeTower.toMillis() + profileStorage.nextTimeTower = nextTimeTower } } } @@ -435,7 +435,7 @@ object ChocolateFactoryDataLoader { list.filter { !it.isMaxed && it.slotIndex != ChocolateFactoryAPI.timeTowerIndex && it.effectiveCost != null } val bestUpgrade = notMaxed.minByOrNull { it.effectiveCost ?: Double.MAX_VALUE } - profileStorage.bestUpgradeAvailableAt = bestUpgrade?.canAffordAt?.toMillis() ?: 0 + profileStorage.bestUpgradeAvailableAt = bestUpgrade?.canAffordAt ?: SimpleTimeMark.farPast() profileStorage.bestUpgradeCost = bestUpgrade?.price ?: 0 ChocolateFactoryAPI.bestPossibleSlot = bestUpgrade?.getValidUpgradeIndex() ?: -1 diff --git a/src/main/java/at/hannibal2/skyhanni/features/inventory/chocolatefactory/ChocolateFactoryTimeTowerManager.kt b/src/main/java/at/hannibal2/skyhanni/features/inventory/chocolatefactory/ChocolateFactoryTimeTowerManager.kt index ba410d145..4d4fdf068 100644 --- a/src/main/java/at/hannibal2/skyhanni/features/inventory/chocolatefactory/ChocolateFactoryTimeTowerManager.kt +++ b/src/main/java/at/hannibal2/skyhanni/features/inventory/chocolatefactory/ChocolateFactoryTimeTowerManager.kt @@ -12,7 +12,6 @@ import at.hannibal2.skyhanni.utils.SoundUtils import net.minecraftforge.fml.common.eventhandler.SubscribeEvent import kotlin.time.Duration import kotlin.time.Duration.Companion.hours -import kotlin.time.Duration.Companion.milliseconds import kotlin.time.Duration.Companion.minutes import kotlin.time.Duration.Companion.seconds @@ -30,8 +29,8 @@ object ChocolateFactoryTimeTowerManager { if (!LorenzUtils.inSkyBlock) return val profileStorage = profileStorage ?: return - if (SimpleTimeMark(profileStorage.currentTimeTowerEnds).isInPast()) { - profileStorage.currentTimeTowerEnds = SimpleTimeMark.farPast().toMillis() + if (profileStorage.currentTimeTowerEnds.isInPast()) { + profileStorage.currentTimeTowerEnds = SimpleTimeMark.farPast() } if (ChocolateFactoryAPI.inChocolateFactory) return @@ -40,13 +39,13 @@ object ChocolateFactoryTimeTowerManager { timeTowerReminder() } - val nextCharge = SimpleTimeMark(profileStorage.nextTimeTower) + val nextCharge = profileStorage.nextTimeTower if (nextCharge.isInPast() && !nextCharge.isFarPast() && currentCharges() < maxCharges()) { profileStorage.currentTimeTowerUses++ - val nextTimeTower = SimpleTimeMark(profileStorage.nextTimeTower) + (profileStorage.timeTowerCooldown).hours - profileStorage.nextTimeTower = nextTimeTower.toMillis() + val nextTimeTower = profileStorage.nextTimeTower + (profileStorage.timeTowerCooldown).hours + profileStorage.nextTimeTower = nextTimeTower if (!config.timeTowerWarning) return ChatUtils.clickableChat( @@ -98,20 +97,20 @@ object ChocolateFactoryTimeTowerManager { fun timeTowerFull() = currentCharges() >= maxCharges() fun timeTowerActive(): Boolean { - val currentTime = profileStorage?.lastDataSave ?: 0 + val currentTime = profileStorage?.lastDataSave ?: SimpleTimeMark.farPast() val endTime = timeTowerEnds() return endTime > currentTime } - private fun timeTowerEnds(): Long { - return profileStorage?.currentTimeTowerEnds ?: 0 + private fun timeTowerEnds(): SimpleTimeMark { + return profileStorage?.currentTimeTowerEnds ?: SimpleTimeMark.farPast() } private fun timeTowerReminder() { if (lastTimeTowerReminder.passedSince() < 20.seconds) return - val timeUntil = SimpleTimeMark(timeTowerEnds()).timeUntil() + val timeUntil = timeTowerEnds().timeUntil() if (timeUntil < 1.minutes && timeUntil.isPositive()) { ChatUtils.clickableChat( "§cYour Time Tower is about to end! " + @@ -128,7 +127,7 @@ object ChocolateFactoryTimeTowerManager { fun timeTowerFullTimeMark(): SimpleTimeMark { val profileStorage = profileStorage ?: return SimpleTimeMark.farPast() if (timeTowerFull()) return SimpleTimeMark.farPast() - val nextChargeDuration = SimpleTimeMark(profileStorage.nextTimeTower) + val nextChargeDuration = profileStorage.nextTimeTower val remainingChargesAfter = profileStorage.maxTimeTowerUses - (profileStorage.currentTimeTowerUses + 1) val endTime = nextChargeDuration + ChocolateFactoryAPI.timeTowerChargeDuration() * remainingChargesAfter @@ -137,11 +136,11 @@ object ChocolateFactoryTimeTowerManager { fun timeTowerActiveDuration(): Duration { if (!timeTowerActive()) return Duration.ZERO - val currentTime = profileStorage?.lastDataSave ?: 0 - val endTime = profileStorage?.currentTimeTowerEnds ?: 0 + val currentTime = profileStorage?.lastDataSave ?: SimpleTimeMark.farPast() + val endTime = profileStorage?.currentTimeTowerEnds ?: SimpleTimeMark.farPast() val duration = endTime - currentTime - return duration.milliseconds + return duration } @SubscribeEvent diff --git a/src/main/java/at/hannibal2/skyhanni/features/inventory/chocolatefactory/ChocolateFactoryUpgradeWarning.kt b/src/main/java/at/hannibal2/skyhanni/features/inventory/chocolatefactory/ChocolateFactoryUpgradeWarning.kt index 04d61966e..e04a882fe 100644 --- a/src/main/java/at/hannibal2/skyhanni/features/inventory/chocolatefactory/ChocolateFactoryUpgradeWarning.kt +++ b/src/main/java/at/hannibal2/skyhanni/features/inventory/chocolatefactory/ChocolateFactoryUpgradeWarning.kt @@ -27,7 +27,7 @@ object ChocolateFactoryUpgradeWarning { if (!LorenzUtils.inSkyBlock) return val profileStorage = profileStorage ?: return - val upgradeAvailableAt = SimpleTimeMark(profileStorage.bestUpgradeAvailableAt) + val upgradeAvailableAt = profileStorage.bestUpgradeAvailableAt if (upgradeAvailableAt.isInPast() && !upgradeAvailableAt.isFarPast()) { checkUpgradeWarning() } diff --git a/src/main/java/at/hannibal2/skyhanni/features/inventory/chocolatefactory/ChocolatePositionChange.kt b/src/main/java/at/hannibal2/skyhanni/features/inventory/chocolatefactory/ChocolatePositionChange.kt index f71a4b341..8aac00e5b 100644 --- a/src/main/java/at/hannibal2/skyhanni/features/inventory/chocolatefactory/ChocolatePositionChange.kt +++ b/src/main/java/at/hannibal2/skyhanni/features/inventory/chocolatefactory/ChocolatePositionChange.kt @@ -14,7 +14,7 @@ object ChocolatePositionChange { fun update(position: Int?, leaderboard: String) { position ?: return val storage = storage ?: return - val lastTime = storage.lastTime?.let { SimpleTimeMark(it) } + val lastTime = storage.lastTime val lastPosition = storage.lastPosition val lastLeaderboard = storage.lastLeaderboard @@ -34,7 +34,7 @@ object ChocolatePositionChange { } } - storage.lastTime = SimpleTimeMark.now().toMillis() + storage.lastTime = SimpleTimeMark.now() storage.lastLeaderboard = leaderboard storage.lastPosition = position } diff --git a/src/main/java/at/hannibal2/skyhanni/utils/GenericWrapper.kt b/src/main/java/at/hannibal2/skyhanni/utils/GenericWrapper.kt new file mode 100644 index 000000000..c390c0559 --- /dev/null +++ b/src/main/java/at/hannibal2/skyhanni/utils/GenericWrapper.kt @@ -0,0 +1,9 @@ +package at.hannibal2.skyhanni.utils + +class GenericWrapper<T>(val it: T) { + companion object { + @JvmStatic + @JvmName("getSimpleTimeMark") + fun getSimpleTimeMark(it: SimpleTimeMark) = GenericWrapper(it) + } +} diff --git a/src/main/java/at/hannibal2/skyhanni/utils/SimpleTimeMark.kt b/src/main/java/at/hannibal2/skyhanni/utils/SimpleTimeMark.kt index 2184322e5..4e6df449e 100644 --- a/src/main/java/at/hannibal2/skyhanni/utils/SimpleTimeMark.kt +++ b/src/main/java/at/hannibal2/skyhanni/utils/SimpleTimeMark.kt @@ -33,9 +33,10 @@ value class SimpleTimeMark(private val millis: Long) : Comparable<SimpleTimeMark override fun compareTo(other: SimpleTimeMark): Int = millis.compareTo(other.millis) - override fun toString(): String { - if (millis == 0L) return "The Far Past" - return Instant.ofEpochMilli(millis).toString() + override fun toString(): String = when (this) { + farPast() -> "The Far Past" + farFuture() -> "The Far Future" + else -> Instant.ofEpochMilli(millis).toString() } fun formattedDate(pattern: String): String { @@ -60,6 +61,9 @@ value class SimpleTimeMark(private val millis: Long) : Comparable<SimpleTimeMark companion object { fun now() = SimpleTimeMark(System.currentTimeMillis()) + + @JvmStatic + @JvmName("farPast") fun farPast() = SimpleTimeMark(0) fun farFuture() = SimpleTimeMark(Long.MAX_VALUE) |