Skip to content

Commit

Permalink
mypy
Browse files Browse the repository at this point in the history
  • Loading branch information
thusser committed Dec 20, 2023
1 parent 312d8dc commit fc7532e
Show file tree
Hide file tree
Showing 4 changed files with 31 additions and 20 deletions.
2 changes: 1 addition & 1 deletion pyobs/comm/dbus/patch.py
Original file line number Diff line number Diff line change
Expand Up @@ -14,7 +14,7 @@
from dbus_next import introspection as intr


def patch():
def patch() -> None:
"""
Patches dbus-next to allow for a providing the sender name. Probably a bad idea, but better than using
a fork of the project.
Expand Down
20 changes: 15 additions & 5 deletions pyobs/comm/dummy/dummycomm.py
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
import inspect
import logging
from typing import Any, List, Type
from typing import Any, List, Type, Dict

from pyobs.comm import Comm
from pyobs.events import Event
Expand All @@ -22,16 +22,26 @@ def clients(self) -> List[str]:
"""Always return zero clients."""
return []

def get_interfaces(self, client: str) -> List[Type[Interface]]:
async def get_interfaces(self, client: str) -> List[Type[Interface]]:
"""No interfaces implemented."""
return []

def _supports_interface(self, client: str, interface: Type[Interface]) -> bool:
async def _supports_interface(self, client: str, interface: Type[Interface]) -> bool:
"""Interfaces are never supported."""
return False

def execute(self, client: str, method: str, signature: inspect.Signature, *args: Any) -> Future:
"""Always fake a successful execution of a method."""
async def execute(self, client: str, method: str, annotation: Dict[str, Any], *args: Any) -> Any:
"""Execute a given method on a remote client.
Args:
client (str): ID of client.
method (str): Method to call.
annotation: Method annotation.
*args: List of parameters for given method.
Returns:
Passes through return from method call.
"""
return Future(empty=True)

@property
Expand Down
19 changes: 10 additions & 9 deletions pyobs/comm/local/localcomm.py
Original file line number Diff line number Diff line change
Expand Up @@ -9,16 +9,15 @@


class LocalComm(Comm):
def __init__(self, name: str, *args, **kwargs):

def __init__(self, name: str, *args: Any, **kwargs: Any):
Comm.__init__(self, *args, **kwargs)

self._name = name
self._network = pyobs.comm.local.LocalNetwork()
self._network.connect_client(self)

@property
def name(self) -> Optional[str]:
def name(self) -> str:
"""Name of this client."""
return self._name

Expand All @@ -45,7 +44,7 @@ async def get_interfaces(self, client: str) -> List[Type[Interface]]:
"""

remote_client: LocalComm = self._network.get_client(client)
return remote_client.module.interfaces
return [] if remote_client.module is None else remote_client.module.interfaces

async def _supports_interface(self, client: str, interface: Type[Interface]) -> bool:
"""Checks, whether the given client supports the given interface.
Expand All @@ -55,10 +54,10 @@ async def _supports_interface(self, client: str, interface: Type[Interface]) ->
interface: Interface to check.
Returns:
Whether or not interface is supported.
Whether interface is supported.
"""
interfaces = await self.get_interfaces(client)
return interfaces in interfaces
return interface in interfaces

async def execute(self, client: str, method: str, annotation: Dict[str, Any], *args: Any) -> Any:
"""Execute a given method on a remote client.
Expand All @@ -74,10 +73,12 @@ async def execute(self, client: str, method: str, annotation: Dict[str, Any], *a
"""

remote_client = self._network.get_client(client)
if remote_client.module is None:
raise ValueError
simple_results = await remote_client.module.execute(method, *args)
real_results = cast_response_to_real(
simple_results, annotation["return"], self.cast_to_real_pre, self.cast_to_real_post
)
simple_results, annotation["return"], self.cast_to_real_pre, self.cast_to_real_post
)
return real_results

async def send_event(self, event: Event) -> None:
Expand All @@ -94,4 +95,4 @@ async def send_event(self, event: Event) -> None:
async def _register_events(
self, events: List[Type[Event]], handler: Optional[Callable[[Event, str], Coroutine[Any, Any, bool]]] = None
) -> None:
pass
pass
10 changes: 5 additions & 5 deletions pyobs/comm/local/localnetwork.py
Original file line number Diff line number Diff line change
@@ -1,25 +1,25 @@
from __future__ import annotations

from typing import Dict, List
from typing import Dict, List, Optional
from typing import TYPE_CHECKING

if TYPE_CHECKING:
import pyobs.comm


class LocalNetwork:
_instance = None
_instance: Optional["LocalNetwork"] = None

def __new__(cls):
def __new__(cls) -> "LocalNetwork":
if cls._instance is None:
print('Creating the object')
print("Creating the object")
cls._instance = super(LocalNetwork, cls).__new__(cls)

cls._clients: Dict[str, pyobs.comm.local.LocalComm] = {}

return cls._instance

def connect_client(self, comm: pyobs.comm.local.LocalComm):
def connect_client(self, comm: pyobs.comm.local.LocalComm) -> None:
self._clients[comm.name] = comm

def get_client(self, name: str) -> pyobs.comm.local.LocalComm:
Expand Down

0 comments on commit fc7532e

Please sign in to comment.