VeloCT_Base / lib /timer.py
Taperx's picture
Deploy Base model with clean official lichess-bot folder
3014f14
Raw
History Blame Contribute Delete
3.22 kB
"""A timer for use in lichess-bot."""
from datetime import timedelta
from time import perf_counter
def msec(time_in_msec: float) -> timedelta:
"""Create a timedelta duration in milliseconds."""
return timedelta(milliseconds=time_in_msec)
def to_msec(duration: timedelta) -> float:
"""Return a bare number representing the length of the duration in milliseconds."""
return duration / msec(1)
def msec_str(duration: timedelta) -> str:
"""Return a string with the duration value in whole number milliseconds."""
return str(round(to_msec(duration)))
def seconds(time_in_sec: float) -> timedelta:
"""Create a timedelta duration in seconds."""
return timedelta(seconds=time_in_sec)
def to_seconds(duration: timedelta) -> float:
"""Return a bare number representing the length of the duration in seconds."""
return duration.total_seconds()
def sec_str(duration: timedelta) -> str:
"""Return a string with the duration value in whole number seconds."""
return str(round(to_seconds(duration)))
def minutes(time_in_minutes: float) -> timedelta:
"""Create a timedelta duration in minutes."""
return timedelta(minutes=time_in_minutes)
def hours(time_in_hours: float) -> timedelta:
"""Create a timedelta duration in hours."""
return timedelta(hours=time_in_hours)
def days(time_in_days: float) -> timedelta:
"""Create a timedelta duration in days."""
return timedelta(days=time_in_days)
def years(time_in_years: float) -> timedelta:
"""Create a timedelta duration in median years--i.e., 365 days."""
return days(365) * time_in_years
zero_seconds = seconds(0)
class Timer:
"""
A timer for use in lichess-bot. An instance of timer can be used both as a countdown timer and a stopwatch.
If the duration argument in the __init__() method is greater than zero, then
the method is_expired() indicates when the initial duration has passed. The
method time_until_expiration() gives the amount of time left until the timer
expires.
Regardless of the initial duration (even if it's zero), a timer can be used
as a stopwatch by calling time_since_reset() to get the amount of time since
the timer was created or since it was last reset.
"""
def __init__(self, duration: timedelta = zero_seconds) -> None:
"""
Start the timer.
:param duration: The duration of time before Timer.is_expired() returns True.
:param backdated_timestamp: When the timer should have started. Used to keep the timers between sessions.
"""
self.duration = duration
self.starting_time = perf_counter()
def is_expired(self) -> bool:
"""Check if a timer is expired."""
return self.time_since_reset() >= self.duration
def reset(self) -> None:
"""Reset the timer."""
self.starting_time = perf_counter()
def time_since_reset(self) -> timedelta:
"""How much time has passed."""
return seconds(perf_counter() - self.starting_time)
def time_until_expiration(self) -> timedelta:
"""How much time is left until it expires."""
return max(seconds(0), self.duration - self.time_since_reset())