summaryrefslogtreecommitdiff
path: root/kvmd/plugins/ugpio/gpio.py
diff options
context:
space:
mode:
authorDevaev Maxim <[email protected]>2020-09-08 05:05:40 +0300
committerDevaev Maxim <[email protected]>2020-09-08 05:05:40 +0300
commit4cc60e4d528c669af0c1f7478160ff57a4691af7 (patch)
tree00778880ef828ac7a71c86348c155d3e59be2854 /kvmd/plugins/ugpio/gpio.py
parent1353ca2e974a66e7797dadba0a89fcbe470c7c7c (diff)
refactoring
Diffstat (limited to 'kvmd/plugins/ugpio/gpio.py')
-rw-r--r--kvmd/plugins/ugpio/gpio.py23
1 files changed, 17 insertions, 6 deletions
diff --git a/kvmd/plugins/ugpio/gpio.py b/kvmd/plugins/ugpio/gpio.py
index 526397e1..96c3eee7 100644
--- a/kvmd/plugins/ugpio/gpio.py
+++ b/kvmd/plugins/ugpio/gpio.py
@@ -36,7 +36,16 @@ from . import BaseUserGpioDriver
# =====
class Plugin(BaseUserGpioDriver):
- def __init__(self, state_poll: float) -> None: # pylint: disable=super-init-not-called
+ def __init__(
+ self,
+ instance_name: str,
+ notifier: aiotools.AioNotifier,
+
+ state_poll: float,
+ ) -> None:
+
+ super().__init__(instance_name, notifier)
+
self.__state_poll = state_poll
self.__input_pins: Set[int] = set()
@@ -50,16 +59,13 @@ class Plugin(BaseUserGpioDriver):
"state_poll": Option(0.1, type=valid_float_f01),
}
- def get_instance_name(self) -> str:
- return "gpio"
-
def register_input(self, pin: int) -> None:
self.__input_pins.add(pin)
def register_output(self, pin: int, initial: Optional[bool]) -> None:
self.__output_pins[pin] = initial
- def prepare(self, notifier: aiotools.AioNotifier) -> None:
+ def prepare(self) -> None:
assert self.__reader is None
self.__reader = gpio.BatchReader(
pins=set([
@@ -70,7 +76,7 @@ class Plugin(BaseUserGpioDriver):
],
]),
interval=self.__state_poll,
- notifier=notifier,
+ notifier=self._notifier,
)
async def run(self) -> None:
@@ -82,3 +88,8 @@ class Plugin(BaseUserGpioDriver):
def write(self, pin: int, state: bool) -> None:
gpio.write(pin, state)
+
+ def __str__(self) -> str:
+ return f"GPIO({self._instance_name})"
+
+ __repr__ = __str__