|
1
|
|
|
""" |
|
2
|
|
|
* PyDMXControl: A Python 3 module to control DMX using OpenDMX or uDMX. |
|
3
|
|
|
* Featuring fixture profiles, built-in effects and a web control panel. |
|
4
|
|
|
* <https://github.com/MattIPv4/PyDMXControl/> |
|
5
|
|
|
* Copyright (C) 2019 Matt Cowley (MattIPv4) ([email protected]) |
|
6
|
|
|
""" |
|
7
|
|
|
|
|
8
|
|
|
from inspect import getsource |
|
9
|
|
|
from time import time |
|
10
|
|
|
from typing import Dict, Union |
|
11
|
|
|
|
|
12
|
|
|
|
|
13
|
|
|
class TimedEvent: |
|
14
|
|
|
|
|
15
|
|
|
def __init__(self, run_time: int, callback: callable, args: tuple = (), name: str = ""): |
|
16
|
|
|
self.__time = run_time |
|
17
|
|
|
self.__cb = callback |
|
18
|
|
|
self.__args = args |
|
19
|
|
|
self.__name = name |
|
20
|
|
|
self.__fired = None |
|
21
|
|
|
|
|
22
|
|
|
@property |
|
23
|
|
|
def time(self) -> str: |
|
24
|
|
|
return "{}ms".format("{:,.4f}".format(self.__time).rstrip("0").rstrip(".")) |
|
25
|
|
|
|
|
26
|
|
|
@property |
|
27
|
|
|
def name(self) -> str: |
|
28
|
|
|
return "{}".format(self.__name) |
|
29
|
|
|
|
|
30
|
|
|
@property |
|
31
|
|
|
def func(self) -> str: |
|
32
|
|
|
return "<func {}>".format(self.__cb.__name__) |
|
33
|
|
|
|
|
34
|
|
|
@property |
|
35
|
|
|
def args(self) -> str: |
|
36
|
|
|
return "[{}]".format(", ".join(["{}".format(f) for f in self.__args])) |
|
37
|
|
|
|
|
38
|
|
|
@property |
|
39
|
|
|
def source(self) -> str: |
|
40
|
|
|
return getsource(self.__cb) |
|
41
|
|
|
|
|
42
|
|
|
@property |
|
43
|
|
|
def fired(self) -> str: |
|
44
|
|
|
if self.__fired is None: |
|
45
|
|
|
return "" |
|
46
|
|
|
return "{:,.4f}ms ({:,.4f}ms late)".format(self.__fired, self.__fired - self.__time) |
|
47
|
|
|
|
|
48
|
|
|
@property |
|
49
|
|
|
def data(self) -> Dict[str, Union[None, str, float, int]]: |
|
50
|
|
|
return { |
|
51
|
|
|
"time": self.time, |
|
52
|
|
|
"time_raw": self.__time, |
|
53
|
|
|
"name": self.name, |
|
54
|
|
|
"func": self.func, |
|
55
|
|
|
"args": self.args, |
|
56
|
|
|
"source": self.source, |
|
57
|
|
|
"fired": self.fired, |
|
58
|
|
|
"fired_raw": None if self.__fired is None else self.__fired, |
|
59
|
|
|
"fired_late_raw": None if self.__fired is None else self.__fired - self.__time |
|
60
|
|
|
} |
|
61
|
|
|
|
|
62
|
|
|
def __str__(self) -> str: |
|
63
|
|
|
return "Event {} (\"{}\") {}".format(self.__time, self.name, self.func) |
|
64
|
|
|
|
|
65
|
|
|
def run(self, start_time) -> str: |
|
66
|
|
|
self.__cb(*self.__args) |
|
67
|
|
|
self.__fired = (time() * 1000.0) - start_time |
|
68
|
|
|
return "{} fired at {}".format(str(self), self.fired) |
|
69
|
|
|
|
|
70
|
|
|
def reset_fired(self): |
|
71
|
|
|
self.__fired = None |
|
72
|
|
|
|