mirror of
https://github.com/davidhalter/typeshed.git
synced 2025-12-07 04:34:28 +08:00
137 lines
5.4 KiB
Python
137 lines
5.4 KiB
Python
import sys
|
|
import types
|
|
from _typeshed import Self, SupportsAllComparisons, SupportsItems
|
|
from typing import Any, Callable, Generic, Hashable, Iterable, NamedTuple, Sequence, Sized, TypeVar, overload
|
|
from typing_extensions import Literal, final
|
|
|
|
if sys.version_info >= (3, 9):
|
|
from types import GenericAlias
|
|
|
|
_AnyCallable = Callable[..., Any]
|
|
|
|
_T = TypeVar("_T")
|
|
_S = TypeVar("_S")
|
|
|
|
@overload
|
|
def reduce(function: Callable[[_T, _S], _T], sequence: Iterable[_S], initial: _T) -> _T: ...
|
|
@overload
|
|
def reduce(function: Callable[[_T, _T], _T], sequence: Iterable[_T]) -> _T: ...
|
|
|
|
class _CacheInfo(NamedTuple):
|
|
hits: int
|
|
misses: int
|
|
maxsize: int
|
|
currsize: int
|
|
|
|
@final
|
|
class _lru_cache_wrapper(Generic[_T]):
|
|
__wrapped__: Callable[..., _T]
|
|
def __call__(self, *args: Hashable, **kwargs: Hashable) -> _T: ...
|
|
def cache_info(self) -> _CacheInfo: ...
|
|
def cache_clear(self) -> None: ...
|
|
|
|
if sys.version_info >= (3, 8):
|
|
@overload
|
|
def lru_cache(maxsize: int | None = ..., typed: bool = ...) -> Callable[[Callable[..., _T]], _lru_cache_wrapper[_T]]: ...
|
|
@overload
|
|
def lru_cache(maxsize: Callable[..., _T], typed: bool = ...) -> _lru_cache_wrapper[_T]: ...
|
|
|
|
else:
|
|
def lru_cache(maxsize: int | None = ..., typed: bool = ...) -> Callable[[Callable[..., _T]], _lru_cache_wrapper[_T]]: ...
|
|
|
|
WRAPPER_ASSIGNMENTS: tuple[
|
|
Literal["__module__"], Literal["__name__"], Literal["__qualname__"], Literal["__doc__"], Literal["__annotations__"],
|
|
]
|
|
WRAPPER_UPDATES: tuple[Literal["__dict__"]]
|
|
|
|
def update_wrapper(wrapper: _T, wrapped: _AnyCallable, assigned: Sequence[str] = ..., updated: Sequence[str] = ...) -> _T: ...
|
|
def wraps(wrapped: _AnyCallable, assigned: Sequence[str] = ..., updated: Sequence[str] = ...) -> Callable[[_T], _T]: ...
|
|
def total_ordering(cls: type[_T]) -> type[_T]: ...
|
|
def cmp_to_key(mycmp: Callable[[_T, _T], int]) -> Callable[[_T], SupportsAllComparisons]: ...
|
|
|
|
class partial(Generic[_T]):
|
|
func: Callable[..., _T]
|
|
args: tuple[Any, ...]
|
|
keywords: dict[str, Any]
|
|
def __new__(cls: type[Self], __func: Callable[..., _T], *args: Any, **kwargs: Any) -> Self: ...
|
|
def __call__(__self, *args: Any, **kwargs: Any) -> _T: ...
|
|
if sys.version_info >= (3, 9):
|
|
def __class_getitem__(cls, item: Any) -> GenericAlias: ...
|
|
|
|
# With protocols, this could change into a generic protocol that defines __get__ and returns _T
|
|
_Descriptor = Any
|
|
|
|
class partialmethod(Generic[_T]):
|
|
func: Callable[..., _T] | _Descriptor
|
|
args: tuple[Any, ...]
|
|
keywords: dict[str, Any]
|
|
@overload
|
|
def __init__(self, __func: Callable[..., _T], *args: Any, **keywords: Any) -> None: ...
|
|
@overload
|
|
def __init__(self, __func: _Descriptor, *args: Any, **keywords: Any) -> None: ...
|
|
def __get__(self, obj: Any, cls: type[Any]) -> Callable[..., _T]: ...
|
|
@property
|
|
def __isabstractmethod__(self) -> bool: ...
|
|
if sys.version_info >= (3, 9):
|
|
def __class_getitem__(cls, item: Any) -> GenericAlias: ...
|
|
|
|
class _SingleDispatchCallable(Generic[_T]):
|
|
registry: types.MappingProxyType[Any, Callable[..., _T]]
|
|
def dispatch(self, cls: Any) -> Callable[..., _T]: ...
|
|
# @fun.register(complex)
|
|
# def _(arg, verbose=False): ...
|
|
@overload
|
|
def register(self, cls: type[Any], func: None = ...) -> Callable[[Callable[..., _T]], Callable[..., _T]]: ...
|
|
# @fun.register
|
|
# def _(arg: int, verbose=False):
|
|
@overload
|
|
def register(self, cls: Callable[..., _T], func: None = ...) -> Callable[..., _T]: ...
|
|
# fun.register(int, lambda x: x)
|
|
@overload
|
|
def register(self, cls: type[Any], func: Callable[..., _T]) -> Callable[..., _T]: ...
|
|
def _clear_cache(self) -> None: ...
|
|
def __call__(__self, *args: Any, **kwargs: Any) -> _T: ...
|
|
|
|
def singledispatch(func: Callable[..., _T]) -> _SingleDispatchCallable[_T]: ...
|
|
|
|
if sys.version_info >= (3, 8):
|
|
class singledispatchmethod(Generic[_T]):
|
|
dispatcher: _SingleDispatchCallable[_T]
|
|
func: Callable[..., _T]
|
|
def __init__(self, func: Callable[..., _T]) -> None: ...
|
|
@property
|
|
def __isabstractmethod__(self) -> bool: ...
|
|
@overload
|
|
def register(self, cls: type[Any], method: None = ...) -> Callable[[Callable[..., _T]], Callable[..., _T]]: ...
|
|
@overload
|
|
def register(self, cls: Callable[..., _T], method: None = ...) -> Callable[..., _T]: ...
|
|
@overload
|
|
def register(self, cls: type[Any], method: Callable[..., _T]) -> Callable[..., _T]: ...
|
|
def __call__(self, *args: Any, **kwargs: Any) -> _T: ...
|
|
|
|
class cached_property(Generic[_T]):
|
|
func: Callable[[Any], _T]
|
|
attrname: str | None
|
|
def __init__(self, func: Callable[[Any], _T]) -> None: ...
|
|
@overload
|
|
def __get__(self, instance: None, owner: type[Any] | None = ...) -> cached_property[_T]: ...
|
|
@overload
|
|
def __get__(self, instance: object, owner: type[Any] | None = ...) -> _T: ...
|
|
def __set_name__(self, owner: type[Any], name: str) -> None: ...
|
|
if sys.version_info >= (3, 9):
|
|
def __class_getitem__(cls, item: Any) -> GenericAlias: ...
|
|
|
|
if sys.version_info >= (3, 9):
|
|
def cache(__user_function: Callable[..., _T]) -> _lru_cache_wrapper[_T]: ...
|
|
|
|
def _make_key(
|
|
args: tuple[Hashable, ...],
|
|
kwds: SupportsItems[Any, Any],
|
|
typed: bool,
|
|
kwd_mark: tuple[object, ...] = ...,
|
|
fasttypes: set[type] = ...,
|
|
tuple: type = ...,
|
|
type: Any = ...,
|
|
len: Callable[[Sized], int] = ...,
|
|
) -> Hashable: ...
|