mirror of
https://github.com/davidhalter/typeshed.git
synced 2025-12-06 20:24:30 +08:00
* Update stubs for `collections` module in both Pythons. * Update `typing.NamedTuple` stub to have `_source` attribute. * Fix compatibility of `deque.index` signature with supertype `Sequence`
111 lines
4.3 KiB
Python
111 lines
4.3 KiB
Python
# Stubs for collections
|
|
|
|
# Based on http://docs.python.org/2.7/library/collections.html
|
|
|
|
# These are not exported.
|
|
import typing
|
|
from typing import Dict, Generic, TypeVar, Tuple, overload, Type, Optional, List, Union, Reversible
|
|
|
|
# These are exported.
|
|
from typing import (
|
|
Callable as Callable,
|
|
Container as Container,
|
|
Hashable as Hashable,
|
|
ItemsView as ItemsView,
|
|
Iterable as Iterable,
|
|
Iterator as Iterator,
|
|
KeysView as KeysView,
|
|
Mapping as Mapping,
|
|
MappingView as MappingView,
|
|
MutableMapping as MutableMapping,
|
|
MutableSequence as MutableSequence,
|
|
MutableSet as MutableSet,
|
|
Sequence as Sequence,
|
|
AbstractSet as Set,
|
|
Sized as Sized,
|
|
ValuesView as ValuesView,
|
|
)
|
|
|
|
_T = TypeVar('_T')
|
|
_KT = TypeVar('_KT')
|
|
_VT = TypeVar('_VT')
|
|
|
|
# namedtuple is special-cased in the type checker; the initializer is ignored.
|
|
def namedtuple(typename: Union[str, unicode], field_names: Union[str, unicode, Iterable[Union[str, unicode]]], *,
|
|
verbose: bool = ..., rename: bool = ...) -> Type[tuple]: ...
|
|
|
|
class deque(Sized, Iterable[_T], Reversible[_T], Generic[_T]):
|
|
def __init__(self, iterable: Iterable[_T] = ...,
|
|
maxlen: int = ...) -> None: ...
|
|
@property
|
|
def maxlen(self) -> Optional[int]: ...
|
|
def append(self, x: _T) -> None: ...
|
|
def appendleft(self, x: _T) -> None: ...
|
|
def clear(self) -> None: ...
|
|
def count(self, x: _T) -> int: ...
|
|
def extend(self, iterable: Iterable[_T]) -> None: ...
|
|
def extendleft(self, iterable: Iterable[_T]) -> None: ...
|
|
def pop(self) -> _T: ...
|
|
def popleft(self) -> _T: ...
|
|
def remove(self, value: _T) -> None: ...
|
|
def reverse(self) -> None: ...
|
|
def rotate(self, n: int) -> None: ...
|
|
def __len__(self) -> int: ...
|
|
def __iter__(self) -> Iterator[_T]: ...
|
|
def __str__(self) -> str: ...
|
|
def __hash__(self) -> int: ...
|
|
def __getitem__(self, i: int) -> _T: ...
|
|
def __setitem__(self, i: int, x: _T) -> None: ...
|
|
def __contains__(self, o: _T) -> bool: ...
|
|
def __reversed__(self) -> Iterator[_T]: ...
|
|
|
|
class Counter(Dict[_T, int], Generic[_T]):
|
|
@overload
|
|
def __init__(self, **kwargs: int) -> None: ...
|
|
@overload
|
|
def __init__(self, mapping: Mapping[_T, int]) -> None: ...
|
|
@overload
|
|
def __init__(self, iterable: Iterable[_T]) -> None: ...
|
|
def elements(self) -> Iterator[_T]: ...
|
|
def most_common(self, n: int = ...) -> List[_T]: ...
|
|
@overload
|
|
def subtract(self, __mapping: Mapping[_T, int]) -> None: ...
|
|
@overload
|
|
def subtract(self, iterable: Iterable[_T]) -> None: ...
|
|
# The Iterable[Tuple[...]] argument type is not actually desirable
|
|
# (the tuples will be added as keys, breaking type safety) but
|
|
# it's included so that the signature is compatible with
|
|
# Dict.update. Not sure if we should use '# type: ignore' instead
|
|
# and omit the type from the union.
|
|
@overload
|
|
def update(self, m: Mapping[_T, int], **kwargs: int) -> None: ...
|
|
@overload
|
|
def update(self, m: Union[Iterable[_T], Iterable[Tuple[_T, int]]], **kwargs: int) -> None: ...
|
|
|
|
def __add__(self, other: Counter[_T]) -> Counter[_T]: ...
|
|
def __sub__(self, other: Counter[_T]) -> Counter[_T]: ...
|
|
def __and__(self, other: Counter[_T]) -> Counter[_T]: ...
|
|
def __or__(self, other: Counter[_T]) -> Counter[_T]: ...
|
|
def __iadd__(self, other: Counter[_T]) -> Counter[_T]: ...
|
|
def __isub__(self, other: Counter[_T]) -> Counter[_T]: ...
|
|
def __iand__(self, other: Counter[_T]) -> Counter[_T]: ...
|
|
def __ior__(self, other: Counter[_T]) -> Counter[_T]: ...
|
|
|
|
class OrderedDict(Dict[_KT, _VT], Reversible[_KT], Generic[_KT, _VT]):
|
|
def popitem(self, last: bool = ...) -> Tuple[_KT, _VT]: ...
|
|
def __reversed__(self) -> Iterator[_KT]: ...
|
|
|
|
class defaultdict(Dict[_KT, _VT], Generic[_KT, _VT]):
|
|
default_factory = ... # type: Callable[[], _VT]
|
|
@overload
|
|
def __init__(self, **kwargs: _VT) -> None: ...
|
|
@overload
|
|
def __init__(self, default_factory: Optional[Callable[[], _VT]]) -> None: ...
|
|
@overload
|
|
def __init__(self, default_factory: Optional[Callable[[], _VT]],
|
|
map: Mapping[_KT, _VT]) -> None: ...
|
|
@overload
|
|
def __init__(self, default_factory: Optional[Callable[[], _VT]],
|
|
iterable: Iterable[Tuple[_KT, _VT]]) -> None: ...
|
|
def __missing__(self, key: _KT) -> _VT: ...
|