mirror of
https://github.com/thegeeklab/ansible-later.git
synced 2024-11-30 00:30:35 +00:00
153 lines
4.9 KiB
Python
153 lines
4.9 KiB
Python
|
# flake8: noqa: E704
|
||
|
# from https://gist.github.com/WuTheFWasThat/091a17d4b5cab597dfd5d4c2d96faf09
|
||
|
# Stubs for pyrsistent (Python 3.6)
|
||
|
|
||
|
from typing import Any
|
||
|
from typing import AnyStr
|
||
|
from typing import Callable
|
||
|
from typing import Iterable
|
||
|
from typing import List
|
||
|
from typing import Optional
|
||
|
from typing import Mapping
|
||
|
from typing import MutableMapping
|
||
|
from typing import Sequence
|
||
|
from typing import Set
|
||
|
from typing import Union
|
||
|
from typing import Tuple
|
||
|
from typing import Type
|
||
|
from typing import TypeVar
|
||
|
from typing import overload
|
||
|
|
||
|
from pyrsistent.typing import PBag as PBag
|
||
|
from pyrsistent.typing import PDeque as PDeque
|
||
|
from pyrsistent.typing import PList as PList
|
||
|
from pyrsistent.typing import PMap as PMap
|
||
|
from pyrsistent.typing import PMapEvolver as PMapEvolver
|
||
|
from pyrsistent.typing import PSet as PSet
|
||
|
from pyrsistent.typing import PSetEvolver as PSetEvolver
|
||
|
from pyrsistent.typing import PVector as PVector
|
||
|
from pyrsistent.typing import PVectorEvolver as PVectorEvolver
|
||
|
|
||
|
KT = TypeVar('KT')
|
||
|
VT = TypeVar('VT')
|
||
|
|
||
|
def pmap(initial: Mapping[KT, VT] = {}, pre_size: int = 0) -> PMap[KT, VT]: ...
|
||
|
def m(**kwargs: Mapping[KT, VT]) -> PMap[KT, VT]: ...
|
||
|
|
||
|
T = TypeVar('T')
|
||
|
|
||
|
def pvector(iterable: Iterable[T]) -> PVector[T]: ...
|
||
|
def v(*iterable: Iterable[T]) -> PVector[T]: ...
|
||
|
|
||
|
def pset(iterable: Iterable[T] = (), pre_size: int = 8) -> PSet[T]: ...
|
||
|
def s(*iterable: Iterable[T]) -> PSet[T]: ...
|
||
|
|
||
|
# The actual return value (_PField) is irrelevant after a PRecord has been instantiated,
|
||
|
# see https://github.com/tobgu/pyrsistent/blob/master/pyrsistent/_precord.py#L10
|
||
|
def field(
|
||
|
type: Union[Type[T], Sequence[Type[T]]] = (),
|
||
|
invariant: Callable[[Any], Tuple[bool, Optional[str]]] = lambda _: (True, None),
|
||
|
initial: Any = object(),
|
||
|
mandatory: bool = False,
|
||
|
factory: Callable[[Any], T] = lambda x: x,
|
||
|
serializer: Callable[[Any, T], Any] = lambda _, value: value,
|
||
|
) -> T: ...
|
||
|
|
||
|
def pset_field(
|
||
|
item_type: Type[T],
|
||
|
optional: bool = False,
|
||
|
initial: Any = (),
|
||
|
) -> PSet[T]: ...
|
||
|
|
||
|
def pmap_field(
|
||
|
key_type: Type[KT],
|
||
|
value_type: Type[VT],
|
||
|
optional: bool = False,
|
||
|
invariant: Callable[[Any], Tuple[bool, Optional[str]]] = lambda _: (True, None),
|
||
|
) -> PMap[KT, VT]: ...
|
||
|
|
||
|
def pvector_field(
|
||
|
item_type: Type[T],
|
||
|
optional: bool = False,
|
||
|
initial: Any = (),
|
||
|
) -> PVector[T]: ...
|
||
|
|
||
|
def pbag(elements: Iterable[T]) -> PBag[T]: ...
|
||
|
def b(*elements: Iterable[T]) -> PBag[T]: ...
|
||
|
|
||
|
def plist(iterable: Iterable[T] = (), reverse: bool = False) -> PList[T]: ...
|
||
|
def l(*elements: Iterable[T]) -> PList[T]: ...
|
||
|
|
||
|
def pdeque(iterable: Iterable[T], maxlen: Optional[int] = None) -> PDeque[T]: ...
|
||
|
def dq(*iterable: Iterable[T]) -> PDeque[T]: ...
|
||
|
|
||
|
def optional(*typs: Iterable[type]) -> Iterable[type]: ...
|
||
|
|
||
|
T_PRecord = TypeVar('T_PRecord', bound='PRecord')
|
||
|
class PRecord(PMap[AnyStr, Any]):
|
||
|
_precord_fields: dict
|
||
|
_precord_initial_values: dict
|
||
|
|
||
|
def __init__(self, **kwargs: Any) -> None: ...
|
||
|
@classmethod
|
||
|
def create(
|
||
|
cls: Type[T_PRecord],
|
||
|
kwargs: Mapping,
|
||
|
_factory_fields: Optional[Iterable] = None,
|
||
|
ignore_extra: bool = False,
|
||
|
) -> T_PRecord: ...
|
||
|
# This is OK because T_PRecord is a concrete type
|
||
|
def discard(self: T_PRecord, key: KT) -> T_PRecord: ...
|
||
|
def remove(self: T_PRecord, key: KT) -> T_PRecord: ...
|
||
|
def set(self: T_PRecord, key: KT, val: VT) -> T_PRecord: ...
|
||
|
|
||
|
def serialize(format: Any = None) -> MutableMapping: ...
|
||
|
# From pyrsistent documentation:
|
||
|
# This set function differs slightly from that in the PMap
|
||
|
# class. First of all it accepts key-value pairs. Second it accepts multiple key-value
|
||
|
# pairs to perform one, atomic, update of multiple fields.
|
||
|
@overload
|
||
|
def set(self, key: KT, val: VT) -> Any: ...
|
||
|
@overload
|
||
|
def set(self, **kwargs: VT) -> Any: ...
|
||
|
|
||
|
def immutable(
|
||
|
members: Union[str, Iterable[str]] = '',
|
||
|
name: str = 'Immutable',
|
||
|
verbose: bool = False,
|
||
|
) -> Tuple: ... # actually a namedtuple
|
||
|
|
||
|
@overload
|
||
|
def freeze(o: Mapping[KT, VT]) -> PMap[KT, VT]: ...
|
||
|
@overload
|
||
|
def freeze(o: List[T]) -> PVector[T]: ...
|
||
|
@overload
|
||
|
def freeze(o: Tuple[T, ...]) -> Tuple[T, ...]: ...
|
||
|
@overload
|
||
|
def freeze(o: Set[T]) -> PSet[T]: ...
|
||
|
|
||
|
@overload
|
||
|
def thaw(o: PMap[KT, VT]) -> Mapping[KT, VT]: ...
|
||
|
@overload
|
||
|
def thaw(o: PVector[T]) -> List[T]: ...
|
||
|
@overload
|
||
|
def thaw(o: Tuple[T, ...]) -> Tuple[T, ...]: ...
|
||
|
# collections.abc.MutableSet is kind of garbage:
|
||
|
# https://stackoverflow.com/questions/24977898/why-does-collections-mutableset-not-bestow-an-update-method
|
||
|
@overload
|
||
|
def thaw(o: PSet[T]) -> Set[T]: ...
|
||
|
|
||
|
def mutant(fn: Callable) -> Callable: ...
|
||
|
|
||
|
def inc(x: int) -> int: ...
|
||
|
@overload
|
||
|
def discard(evolver: PMapEvolver[KT, VT], key: KT) -> None: ...
|
||
|
@overload
|
||
|
def discard(evolver: PVectorEvolver[T], key: int) -> None: ...
|
||
|
@overload
|
||
|
def discard(evolver: PSetEvolver[T], key: T) -> None: ...
|
||
|
def rex(expr: str) -> Callable[[Any], bool]: ...
|
||
|
def ny(_: Any) -> bool: ...
|
||
|
|
||
|
def get_in(keys: Iterable, coll: Mapping, default: Optional[Any] = None, no_default: bool = False) -> Any: ...
|