From 622e5e20ec186165d88afb8defde03f15d0e6f9e Mon Sep 17 00:00:00 2001 From: David Barnett Date: Sat, 1 Aug 2020 15:38:01 -0700 Subject: [PATCH] Add type hints for typechecked and related decorators --- pytypes/py.typed | 0 pytypes/typechecker.pyi | 26 ++++++++++++++++++++++++++ setup.cfg | 3 +++ 3 files changed, 29 insertions(+) create mode 100644 pytypes/py.typed create mode 100644 pytypes/typechecker.pyi diff --git a/pytypes/py.typed b/pytypes/py.typed new file mode 100644 index 0000000..e69de29 diff --git a/pytypes/typechecker.pyi b/pytypes/typechecker.pyi new file mode 100644 index 0000000..7cdfeec --- /dev/null +++ b/pytypes/typechecker.pyi @@ -0,0 +1,26 @@ +# Generated using mypy stubgen, then filling in types and removing internals. + +from .type_util import TypeAgent +from types import ModuleType +from typing import Any, Optional, Callable, TypeVar + +T_Callable = TypeVar('T_Callable', bound=Callable) +def override(func: T_Callable, auto: bool = ...) -> T_Callable: ... +def typechecked_func(func: T_Callable, force: bool = ..., argType: Optional[Any] = ..., resType: Optional[Any] = ..., prop_getter: bool = ...): ... +def typechecked_class(cls, force: bool = ..., force_recursive: bool = ...): ... +T_Mod = TypeVar('T_Mod', ModuleType, str) +def typechecked_module(md: T_Mod, force_recursive: bool = ...) -> T_Mod: ... + +T = TypeVar('T', Callable, property, type, str, ModuleType) +def typechecked(memb: T) -> T: ... +T_Class = TypeVar('T_Class', bound=type) +def auto_override_class(cls: T_Class, force: bool = ..., force_recursive: bool = ...) -> T_Class: ... +def auto_override_module(md: T_Mod, force_recursive: bool = ...) -> T_Mod: ... +def auto_override(memb: T) -> T: ... +def no_type_check(memb: T) -> T: ... +def is_no_type_check(memb: T) -> bool: ... +def check_argument_types(cllable: Optional[Callable] = ..., call_args: Optional[Any] = ..., clss: Optional[type] = ..., caller_level: int = ...) -> Callable: ... +def check_return_type(value: Any, cllable: Optional[Callable] = ..., clss: Optional[type] = ..., caller_level: int = ...) -> Callable: ... + +class TypeChecker(TypeAgent): + def __init__(self, all_threads: bool = ...) -> None: ... diff --git a/setup.cfg b/setup.cfg index a3cb69a..4776d81 100644 --- a/setup.cfg +++ b/setup.cfg @@ -3,3 +3,6 @@ max-line-length = 99 [wheel] universal = 1 + +[options.package_data] +pytypes = py.typed, *.pyi