diff options
author | Devaev Maxim <[email protected]> | 2019-10-01 21:23:45 +0300 |
---|---|---|
committer | Devaev Maxim <[email protected]> | 2019-10-01 21:23:45 +0300 |
commit | 4d668e9c1aa5162965437f0186924f6e56432bbd (patch) | |
tree | 6f869ab05d0123c3cec2e621b7b67c15c1b370e8 /kvmd | |
parent | f71c06a9a9b349bf3804e698afc6686178f4968f (diff) |
refactoring
Diffstat (limited to 'kvmd')
-rw-r--r-- | kvmd/apps/kvmd/server.py | 20 | ||||
-rw-r--r-- | kvmd/apps/otg/hid/keyboard.py | 4 | ||||
-rw-r--r-- | kvmd/apps/otg/hid/mouse.py | 4 | ||||
-rw-r--r-- | kvmd/plugins/hid/__init__.py | 4 | ||||
-rw-r--r-- | kvmd/plugins/hid/serial.py | 32 |
5 files changed, 32 insertions, 32 deletions
diff --git a/kvmd/apps/kvmd/server.py b/kvmd/apps/kvmd/server.py index 6b68be37..81f2c0b4 100644 --- a/kvmd/apps/kvmd/server.py +++ b/kvmd/apps/kvmd/server.py @@ -383,10 +383,10 @@ class Server: # pylint: disable=too-many-instance-attributes await ws.send_str(json.dumps({"msg_type": "pong"})) elif event_type == "key": await self.__handle_ws_key_event(event) - elif event_type == "mouse_move": - await self.__handle_ws_mouse_move_event(event) elif event_type == "mouse_button": await self.__handle_ws_mouse_button_event(event) + elif event_type == "mouse_move": + await self.__handle_ws_mouse_move_event(event) elif event_type == "mouse_wheel": await self.__handle_ws_mouse_wheel_event(event) else: @@ -403,14 +403,6 @@ class Server: # pylint: disable=too-many-instance-attributes return await self.__hid.send_key_event(key, state) - async def __handle_ws_mouse_move_event(self, event: Dict) -> None: - try: - to_x = valid_hid_mouse_move(event["to"]["x"]) - to_y = valid_hid_mouse_move(event["to"]["y"]) - except Exception: - return - await self.__hid.send_mouse_move_event(to_x, to_y) - async def __handle_ws_mouse_button_event(self, event: Dict) -> None: try: button = valid_hid_mouse_button(event["button"]) @@ -419,6 +411,14 @@ class Server: # pylint: disable=too-many-instance-attributes return await self.__hid.send_mouse_button_event(button, state) + async def __handle_ws_mouse_move_event(self, event: Dict) -> None: + try: + to_x = valid_hid_mouse_move(event["to"]["x"]) + to_y = valid_hid_mouse_move(event["to"]["y"]) + except Exception: + return + await self.__hid.send_mouse_move_event(to_x, to_y) + async def __handle_ws_mouse_wheel_event(self, event: Dict) -> None: try: delta_x = valid_hid_mouse_wheel(event["delta"]["x"]) diff --git a/kvmd/apps/otg/hid/keyboard.py b/kvmd/apps/otg/hid/keyboard.py index 274406fd..29b62e07 100644 --- a/kvmd/apps/otg/hid/keyboard.py +++ b/kvmd/apps/otg/hid/keyboard.py @@ -25,8 +25,8 @@ from . import Hid # ===== KEYBOARD_HID = Hid( - protocol=1, - subclass=1, + protocol=1, # Keyboard protocol + subclass=1, # Boot interface subclass report_length=8, diff --git a/kvmd/apps/otg/hid/mouse.py b/kvmd/apps/otg/hid/mouse.py index bed1ffb2..57e75e43 100644 --- a/kvmd/apps/otg/hid/mouse.py +++ b/kvmd/apps/otg/hid/mouse.py @@ -25,8 +25,8 @@ from . import Hid # ===== MOUSE_HID = Hid( - protocol=0, - subclass=0, + protocol=0, # None protocol + subclass=0, # No subclass report_length=7, diff --git a/kvmd/plugins/hid/__init__.py b/kvmd/plugins/hid/__init__.py index 5bc5ca52..4e0ce5ea 100644 --- a/kvmd/plugins/hid/__init__.py +++ b/kvmd/plugins/hid/__init__.py @@ -51,10 +51,10 @@ class BaseHid(BasePlugin): async def send_key_event(self, key: str, state: bool) -> None: raise NotImplementedError - async def send_mouse_move_event(self, to_x: int, to_y: int) -> None: + async def send_mouse_button_event(self, button: str, state: bool) -> None: raise NotImplementedError - async def send_mouse_button_event(self, button: str, state: bool) -> None: + async def send_mouse_move_event(self, to_x: int, to_y: int) -> None: raise NotImplementedError async def send_mouse_wheel_event(self, delta_x: int, delta_y: int) -> None: diff --git a/kvmd/plugins/hid/serial.py b/kvmd/plugins/hid/serial.py index 4a4346dc..3f9fe23b 100644 --- a/kvmd/plugins/hid/serial.py +++ b/kvmd/plugins/hid/serial.py @@ -82,19 +82,6 @@ class _KeyEvent(_BaseEvent): @dataclasses.dataclass(frozen=True) -class _MouseMoveEvent(_BaseEvent): - to_x: int - to_y: int - - def __post_init__(self) -> None: - assert -32768 <= self.to_x <= 32767 - assert -32768 <= self.to_y <= 32767 - - def make_command(self) -> bytes: - return struct.pack(">Bhh", 0x12, self.to_x, self.to_y) - - [email protected](frozen=True) class _MouseButtonEvent(_BaseEvent): name: str state: bool @@ -114,6 +101,19 @@ class _MouseButtonEvent(_BaseEvent): @dataclasses.dataclass(frozen=True) +class _MouseMoveEvent(_BaseEvent): + to_x: int + to_y: int + + def __post_init__(self) -> None: + assert -32768 <= self.to_x <= 32767 + assert -32768 <= self.to_y <= 32767 + + def make_command(self) -> bytes: + return struct.pack(">Bhh", 0x12, self.to_x, self.to_y) + + [email protected](frozen=True) class _MouseWheelEvent(_BaseEvent): delta_x: int delta_y: int @@ -248,12 +248,12 @@ class Plugin(BaseHid, multiprocessing.Process): # pylint: disable=too-many-inst async def send_key_event(self, key: str, state: bool) -> None: await self.__queue_event(_KeyEvent(key, state)) - async def send_mouse_move_event(self, to_x: int, to_y: int) -> None: - await self.__queue_event(_MouseMoveEvent(to_x, to_y)) - async def send_mouse_button_event(self, button: str, state: bool) -> None: await self.__queue_event(_MouseButtonEvent(button, state)) + async def send_mouse_move_event(self, to_x: int, to_y: int) -> None: + await self.__queue_event(_MouseMoveEvent(to_x, to_y)) + async def send_mouse_wheel_event(self, delta_x: int, delta_y: int) -> None: await self.__queue_event(_MouseWheelEvent(delta_x, delta_y)) |