Skip to content

Commit

Permalink
❔ Add typing types
Browse files Browse the repository at this point in the history
  • Loading branch information
Steffo99 committed Jun 14, 2021
1 parent 82fc6a8 commit 221f954
Show file tree
Hide file tree
Showing 2 changed files with 22 additions and 18 deletions.
35 changes: 19 additions & 16 deletions async_chain/chain.py
Original file line number Diff line number Diff line change
Expand Up @@ -32,20 +32,23 @@ async def __evaluate__(self) -> t.Any:
raise NotImplementedError()


StartingType = t.TypeVar("StartingType")


class ChainStart(Chain):
__slots__ = ("__start__",)

def __init__(self, start: t.Any):
def __init__(self, start: StartingType):
super().__init__()
self.__start__: t.Any = start
self.__start__: StartingType = start

def __repr__(self):
def __repr__(self) -> str:
return f"<Chain {self.__display__()}>"

def __display__(self):
def __display__(self) -> str:
return f"{self.__start__!r}"

async def __evaluate__(self):
async def __evaluate__(self) -> StartingType:
return self.__start__


Expand All @@ -56,7 +59,7 @@ def __init__(self, previous: Chain):
super().__init__()
self.__previous__: Chain = previous

def __repr__(self):
def __repr__(self) -> str:
return f"<Chain {self.__display__()}>"


Expand All @@ -67,10 +70,10 @@ def __init__(self, previous: Chain, item: str):
super().__init__(previous=previous)
self.__item__: str = item

def __display__(self):
def __display__(self) -> str:
return f"{self.__previous__.__display__()}.{self.__item__!s}"

async def __evaluate__(self):
async def __evaluate__(self) -> t.Any:
previous = await self.__previous__.__evaluate__()

current = getattr(previous, self.__item__)
Expand All @@ -88,10 +91,10 @@ def __init__(self, previous: Chain, item: t.Any):
super().__init__(previous=previous)
self.__item__: t.Any = item

def __display__(self):
def __display__(self) -> str:
return f"{self.__previous__.__display__()}[{self.__item__!r}]"

async def __evaluate__(self):
async def __evaluate__(self) -> t.Any:
previous = await self.__previous__.__evaluate__()

current = previous[self.__item__]
Expand All @@ -105,18 +108,18 @@ async def __evaluate__(self):
class ChainCall(ChainNode):
__slots__ = ("__args__", "__kwargs__",)

def __init__(self, previous: Chain, args, kwargs):
def __init__(self, previous: Chain, args: t.Collection[t.Any], kwargs: t.Mapping[str, t.Any]):
super().__init__(previous=previous)
self.__args__ = args
self.__kwargs__ = kwargs
self.__args__: t.Collection[t.Any] = args
self.__kwargs__: t.Mapping[str, t.Any] = kwargs

def __display__(self):
def __display__(self) -> str:
args = map(lambda a: f"{a!r}", self.__args__)
kwargs = map(lambda k, v: f"{k!s}={v!r}", self.__kwargs__)
allargs = ", ".join([*args, *kwargs])
allargs: str = ", ".join([*args, *kwargs])
return f"{self.__previous__.__display__()}({allargs})"

async def __evaluate__(self):
async def __evaluate__(self) -> t.Any:
previous = await self.__previous__.__evaluate__()

current = previous(*self.__args__, **self.__kwargs__)
Expand Down
5 changes: 3 additions & 2 deletions async_chain/decorators.py
Original file line number Diff line number Diff line change
@@ -1,15 +1,16 @@
import functools
import typing as t
from .chain import ChainStart


class FunctionWrapper:
def __init__(self, func):
self._func = func

def __repr__(self):
def __repr__(self) -> str:
return self._func.__name__

def __call__(self, *args, **kwargs):
def __call__(self, *args, **kwargs) -> t.Any:
return self._func(*args, **kwargs)


Expand Down

0 comments on commit 221f954

Please sign in to comment.