summaryrefslogtreecommitdiff
path: root/kvmd/plugins/hid/otg/keyboard.py
diff options
context:
space:
mode:
Diffstat (limited to 'kvmd/plugins/hid/otg/keyboard.py')
-rw-r--r--kvmd/plugins/hid/otg/keyboard.py50
1 files changed, 20 insertions, 30 deletions
diff --git a/kvmd/plugins/hid/otg/keyboard.py b/kvmd/plugins/hid/otg/keyboard.py
index acc0381f..3225d8d2 100644
--- a/kvmd/plugins/hid/otg/keyboard.py
+++ b/kvmd/plugins/hid/otg/keyboard.py
@@ -24,6 +24,7 @@ from typing import Tuple
from typing import List
from typing import Set
from typing import Iterable
+from typing import Generator
from typing import Optional
from typing import Any
@@ -61,7 +62,7 @@ class KeyboardProcess(BaseDeviceProcess):
def cleanup(self) -> None:
self._stop()
get_logger().info("Clearing HID-keyboard events ...")
- self._ensure_write(b"\x00" * 8, close=True) # Release all keys and modifiers
+ self._cleanup_write(b"\x00" * 8) # Release all keys and modifiers
def send_clear_event(self) -> None:
self._clear_queue()
@@ -87,60 +88,49 @@ class KeyboardProcess(BaseDeviceProcess):
# =====
- def _process_event(self, event: BaseEvent) -> bool:
- if isinstance(event, ClearEvent):
- return self.__process_clear_event()
- elif isinstance(event, ResetEvent):
- return self.__process_clear_event(reopen=True)
+ def _process_event(self, event: BaseEvent) -> Generator[bytes, None, None]:
+ if isinstance(event, (ClearEvent, ResetEvent)):
+ yield self.__process_clear_event()
elif isinstance(event, ModifierEvent):
- return self.__process_modifier_event(event)
+ yield from self.__process_modifier_event(event)
elif isinstance(event, KeyEvent):
- return self.__process_key_event(event)
- raise RuntimeError(f"Not implemented event: {event}")
+ yield from self.__process_key_event(event)
+ else:
+ raise RuntimeError(f"Not implemented event: {event}")
- def __process_clear_event(self, reopen: bool=False) -> bool:
+ def __process_clear_event(self) -> bytes:
self.__clear_modifiers()
self.__clear_keys()
- return self.__send_current_state(reopen=reopen)
+ return self.__make_report()
- def __process_modifier_event(self, event: ModifierEvent) -> bool:
+ def __process_modifier_event(self, event: ModifierEvent) -> Generator[bytes, None, None]:
if event.modifier in self.__pressed_modifiers:
# Ранее нажатый модификатор отжимаем
self.__pressed_modifiers.remove(event.modifier)
- if not self.__send_current_state():
- return False
+ yield self.__make_report()
if event.state:
# Нажимаем если нужно
self.__pressed_modifiers.add(event.modifier)
- return self.__send_current_state()
- return True
+ yield self.__make_report()
- def __process_key_event(self, event: KeyEvent) -> bool:
+ def __process_key_event(self, event: KeyEvent) -> Generator[bytes, None, None]:
if event.key in self.__pressed_keys:
# Ранее нажатую клавишу отжимаем
self.__pressed_keys[self.__pressed_keys.index(event.key)] = None
- if not self.__send_current_state():
- return False
+ yield self.__make_report()
elif event.state and None not in self.__pressed_keys:
# Если нужно нажать что-то новое, но свободных слотов нет - отжимаем всё
self.__clear_keys()
- if not self.__send_current_state():
- return False
+ yield self.__make_report()
if event.state:
# Нажимаем если нужно
self.__pressed_keys[self.__pressed_keys.index(None)] = event.key
- return self.__send_current_state()
- return True
+ yield self.__make_report()
# =====
- def __send_current_state(self, reopen: bool=False) -> bool:
- report = make_keyboard_report(self.__pressed_modifiers, self.__pressed_keys)
- if not self._ensure_write(report, reopen=reopen):
- self.__clear_modifiers()
- self.__clear_keys()
- return False
- return True
+ def __make_report(self) -> bytes:
+ return make_keyboard_report(self.__pressed_modifiers, self.__pressed_keys)
def __clear_modifiers(self) -> None:
self.__pressed_modifiers.clear()