blob: 101c54ad7eff02d0019c96d9b61aa38e06590629 [file]
# These builtins stubs are used implicitly in AST to IR generation
# test cases.
import _typeshed
from typing import (
Self, TypeVar, Generic, List, Iterator, Iterable, Dict, Optional, Tuple, Any, Set,
overload, Mapping, Union, Callable, Sequence, FrozenSet, Protocol
)
_T = TypeVar('_T')
T_co = TypeVar('T_co', covariant=True)
T_contra = TypeVar('T_contra', contravariant=True)
_S = TypeVar('_S')
_K = TypeVar('_K') # for keys in mapping
_V = TypeVar('_V') # for values in mapping
class __SupportsAbs(Protocol[T_co]):
def __abs__(self) -> T_co: pass
class __SupportsDivMod(Protocol[T_contra, T_co]):
def __divmod__(self, other: T_contra) -> T_co: ...
class __SupportsRDivMod(Protocol[T_contra, T_co]):
def __rdivmod__(self, other: T_contra) -> T_co: ...
_M = TypeVar("_M", contravariant=True)
class __SupportsPow2(Protocol[T_contra, T_co]):
def __pow__(self, other: T_contra) -> T_co: ...
class __SupportsPow3NoneOnly(Protocol[T_contra, T_co]):
def __pow__(self, other: T_contra, modulo: None = ...) -> T_co: ...
class __SupportsPow3(Protocol[T_contra, _M, T_co]):
def __pow__(self, other: T_contra, modulo: _M) -> T_co: ...
__SupportsSomeKindOfPow = Union[
__SupportsPow2[Any, Any], __SupportsPow3NoneOnly[Any, Any] | __SupportsPow3[Any, Any, Any]
]
class object:
__class__: type
__dict__: dict[str, Any]
def __new__(cls) -> Self: pass
def __init__(self) -> None: pass
def __init_subclass__(cls, **kwargs: object) -> None: pass
def __eq__(self, x: object) -> bool: pass
def __ne__(self, x: object) -> bool: pass
def __str__(self) -> str: pass
def __setattr__(self, k: str, v: object) -> None: pass
def __delattr__(self, k: str) -> None: pass
class type:
def __init__(self, o: object) -> None: ...
def __or__(self, o: object) -> Any: ...
def __new__(cls, *args: object) -> Any: ...
__name__ : str
__annotations__: Dict[str, Any]
class ellipsis: pass
# Primitive types are special in generated code.
class int:
@overload
def __init__(self) -> None: pass
@overload
def __init__(self, x: object, base: int = 10) -> None: pass
def __add__(self, n: int) -> int: pass
def __sub__(self, n: int) -> int: pass
def __mul__(self, n: int) -> int: pass
def __pow__(self, n: int, modulo: Optional[int] = None) -> int: pass
def __floordiv__(self, x: int) -> int: pass
def __truediv__(self, x: float) -> float: pass
def __mod__(self, x: int) -> int: pass
def __divmod__(self, x: float) -> Tuple[float, float]: pass
def __neg__(self) -> int: pass
def __pos__(self) -> int: pass
def __abs__(self) -> int: pass
def __invert__(self) -> int: pass
def __and__(self, n: int) -> int: pass
def __or__(self, n: int) -> int: pass
def __xor__(self, n: int) -> int: pass
def __lshift__(self, x: int) -> int: pass
def __rshift__(self, x: int) -> int: pass
def __eq__(self, n: object) -> bool: pass
def __ne__(self, n: object) -> bool: pass
def __lt__(self, n: int) -> bool: pass
def __gt__(self, n: int) -> bool: pass
def __le__(self, n: int) -> bool: pass
def __ge__(self, n: int) -> bool: pass
def to_bytes(self, length: int, order: str, *, signed: bool = False) -> bytes: pass
def bit_length(self) -> int: pass
class str:
@overload
def __init__(self) -> None: pass
@overload
def __init__(self, x: object) -> None: pass
def __add__(self, x: str) -> str: pass
def __mul__(self, x: int) -> str: pass
def __rmul__(self, x: int) -> str: pass
def __eq__(self, x: object) -> bool: pass
def __ne__(self, x: object) -> bool: pass
def __lt__(self, x: str) -> bool: ...
def __le__(self, x: str) -> bool: ...
def __gt__(self, x: str) -> bool: ...
def __ge__(self, x: str) -> bool: ...
@overload
def __getitem__(self, i: int) -> str: pass
@overload
def __getitem__(self, i: slice) -> str: pass
def __contains__(self, item: str) -> bool: pass
def __iter__(self) -> Iterator[str]: ...
def find(self, sub: str, start: Optional[int] = None, end: Optional[int] = None, /) -> int: ...
def rfind(self, sub: str, start: Optional[int] = None, end: Optional[int] = None, /) -> int: ...
def split(self, sep: Optional[str] = None, maxsplit: int = -1) -> List[str]: pass
def rsplit(self, sep: Optional[str] = None, maxsplit: int = -1) -> List[str]: pass
def splitlines(self, keepends: bool = False) -> List[str]: ...
def strip (self, item: Optional[str] = None) -> str: pass
def lstrip(self, item: Optional[str] = None) -> str: pass
def rstrip(self, item: Optional[str] = None) -> str: pass
def join(self, x: Iterable[str]) -> str: pass
def format(self, *args: Any, **kwargs: Any) -> str: ...
def lower(self) -> str: ...
def upper(self) -> str: ...
def startswith(self, x: Union[str, Tuple[str, ...]], start: int=..., end: int=...) -> bool: ...
def endswith(self, x: Union[str, Tuple[str, ...]], start: int=..., end: int=...) -> bool: ...
def replace(self, old: str, new: str, maxcount: int=...) -> str: ...
def encode(self, encoding: str=..., errors: str=...) -> bytes: ...
def partition(self, sep: str, /) -> Tuple[str, str, str]: ...
def rpartition(self, sep: str, /) -> Tuple[str, str, str]: ...
def removeprefix(self, prefix: str, /) -> str: ...
def removesuffix(self, suffix: str, /) -> str: ...
def islower(self) -> bool: ...
def count(self, substr: str, start: Optional[int] = None, end: Optional[int] = None) -> int: pass
def isspace(self) -> bool: ...
def isalnum(self) -> bool: ...
def isdigit(self) -> bool: ...
class float:
def __init__(self, x: object) -> None: pass
def __add__(self, n: float) -> float: pass
def __radd__(self, n: float) -> float: pass
def __sub__(self, n: float) -> float: pass
def __rsub__(self, n: float) -> float: pass
def __mul__(self, n: float) -> float: pass
def __truediv__(self, n: float) -> float: pass
def __floordiv__(self, n: float) -> float: pass
def __mod__(self, n: float) -> float: pass
def __pow__(self, n: float) -> float: pass
def __neg__(self) -> float: pass
def __pos__(self) -> float: pass
def __abs__(self) -> float: pass
def __invert__(self) -> float: pass
def __eq__(self, x: object) -> bool: pass
def __ne__(self, x: object) -> bool: pass
def __lt__(self, x: float) -> bool: ...
def __le__(self, x: float) -> bool: ...
def __gt__(self, x: float) -> bool: ...
def __ge__(self, x: float) -> bool: ...
class complex:
def __init__(self, x: object, y: object = None) -> None: pass
def __add__(self, n: complex) -> complex: pass
def __radd__(self, n: float) -> complex: pass
def __sub__(self, n: complex) -> complex: pass
def __rsub__(self, n: float) -> complex: pass
def __mul__(self, n: complex) -> complex: pass
def __truediv__(self, n: complex) -> complex: pass
def __neg__(self) -> complex: pass
class bytes:
@overload
def __init__(self) -> None: ...
@overload
def __init__(self, x: object) -> None: ...
def __add__(self, x: bytes | bytearray) -> bytes: ...
def __mul__(self, x: int) -> bytes: ...
def __rmul__(self, x: int) -> bytes: ...
def __eq__(self, x: object) -> bool: ...
def __ne__(self, x: object) -> bool: ...
@overload
def __getitem__(self, i: int) -> int: ...
@overload
def __getitem__(self, i: slice) -> bytes: ...
def join(self, x: Iterable[object]) -> bytes: ...
def decode(self, encoding: str=..., errors: str=...) -> str: ...
def translate(self, t: bytes | bytearray) -> bytes: ...
def startswith(self, t: bytes | bytearray) -> bool: ...
def endswith(self, t: bytes | bytearray) -> bool: ...
def __iter__(self) -> Iterator[int]: ...
class bytearray:
@overload
def __init__(self) -> None: pass
@overload
def __init__(self, x: object) -> None: pass
@overload
def __init__(self, string: str, encoding: str, err: str = ...) -> None: pass
def __add__(self, s: bytes | bytearray) -> bytearray: ...
def __setitem__(self, i: int, o: int) -> None: ...
@overload
def __getitem__(self, i: int) -> int: ...
@overload
def __getitem__(self, i: slice) -> bytearray: ...
def decode(self, x: str = ..., y: str = ...) -> str: ...
def join(self, x: Iterable[object]) -> bytes: ...
def startswith(self, t: bytes) -> bool: ...
def endswith(self, t: bytes) -> bool: ...
def __iter__(self) -> Iterator[int]: ...
class bool(int):
def __init__(self, o: object = ...) -> None: ...
@overload
def __and__(self, n: bool) -> bool: ...
@overload
def __and__(self, n: int) -> int: ...
@overload
def __or__(self, n: bool) -> bool: ...
@overload
def __or__(self, n: int) -> int: ...
@overload
def __xor__(self, n: bool) -> bool: ...
@overload
def __xor__(self, n: int) -> int: ...
class tuple(Generic[T_co], Sequence[T_co], Iterable[T_co]):
def __init__(self, i: Iterable[T_co]) -> None: pass
@overload
def __getitem__(self, i: int) -> T_co: pass
@overload
def __getitem__(self, i: slice) -> Tuple[T_co, ...]: pass
def __len__(self) -> int: pass
def __iter__(self) -> Iterator[T_co]: ...
def __contains__(self, item: object) -> int: ...
@overload
def __add__(self, value: Tuple[T_co, ...], /) -> Tuple[T_co, ...]: ...
@overload
def __add__(self, value: Tuple[_T, ...], /) -> Tuple[T_co | _T, ...]: ...
def __mul__(self, value: int, /) -> Tuple[T_co, ...]: ...
def __rmul__(self, value: int, /) -> Tuple[T_co, ...]: ...
class function: pass
class list(Generic[_T], Sequence[_T], Iterable[_T]):
def __init__(self, i: Optional[Iterable[_T]] = None) -> None: pass
@overload
def __getitem__(self, i: int) -> _T: ...
@overload
def __getitem__(self, s: slice) -> List[_T]: ...
def __setitem__(self, i: int, o: _T) -> None: pass
def __delitem__(self, i: int) -> None: pass
def __mul__(self, i: int) -> List[_T]: pass
def __rmul__(self, i: int) -> List[_T]: pass
def __imul__(self, i: int) -> List[_T]: ...
def __iter__(self) -> Iterator[_T]: pass
def __len__(self) -> int: pass
def __contains__(self, item: object) -> int: ...
@overload
def __add__(self, value: List[_T], /) -> List[_T]: ...
@overload
def __add__(self, value: List[_S], /) -> List[_S | _T]: ...
def __iadd__(self, value: Iterable[_T], /) -> List[_T]: ... # type: ignore[misc]
def append(self, x: _T) -> None: pass
def pop(self, i: int = -1) -> _T: pass
def count(self, x: _T) -> int: pass
def extend(self, l: Iterable[_T]) -> None: pass
def insert(self, i: int, x: _T) -> None: pass
def sort(self) -> None: pass
def reverse(self) -> None: pass
def remove(self, o: _T) -> None: pass
def index(self, o: _T) -> int: pass
def clear(self) -> None: pass
def copy(self) -> List[_T]: pass
class dict(Mapping[_K, _V]):
@overload
def __init__(self, **kwargs: _K) -> None: ...
@overload
def __init__(self, map: Mapping[_K, _V], **kwargs: _V) -> None: ...
@overload
def __init__(self, iterable: Iterable[Tuple[_K, _V]], **kwargs: _V) -> None: ...
def __getitem__(self, key: _K) -> _V: pass
def __setitem__(self, k: _K, v: _V) -> None: pass
def __delitem__(self, k: _K) -> None: pass
def __contains__(self, item: object) -> int: pass
def __iter__(self) -> Iterator[_K]: pass
def __len__(self) -> int: pass
@overload
def update(self, __m: Mapping[_K, _V], **kwargs: _V) -> None: pass
@overload
def update(self, __m: Iterable[Tuple[_K, _V]], **kwargs: _V) -> None: ...
@overload
def update(self, **kwargs: _V) -> None: ...
def pop(self, x: int) -> _K: pass
def keys(self) -> Iterable[_K]: pass
def values(self) -> Iterable[_V]: pass
def items(self) -> Iterable[Tuple[_K, _V]]: pass
def clear(self) -> None: pass
def copy(self) -> Dict[_K, _V]: pass
def setdefault(self, key: _K, val: _V = ...) -> _V: pass
class set(Generic[_T]):
def __init__(self, i: Optional[Iterable[_T]] = None) -> None: pass
def __iter__(self) -> Iterator[_T]: pass
def __len__(self) -> int: pass
def add(self, x: _T) -> None: pass
def remove(self, x: _T) -> None: pass
def discard(self, x: _T) -> None: pass
def clear(self) -> None: pass
def pop(self) -> _T: pass
def update(self, x: Iterable[_S]) -> None: pass
def __or__(self, s: Union[Set[_S], FrozenSet[_S]]) -> Set[Union[_T, _S]]: ...
def __xor__(self, s: Union[Set[_S], FrozenSet[_S]]) -> Set[Union[_T, _S]]: ...
class frozenset(Generic[_T]):
def __init__(self, i: Optional[Iterable[_T]] = None) -> None: pass
def __iter__(self) -> Iterator[_T]: pass
def __len__(self) -> int: pass
def __or__(self, s: Union[Set[_S], FrozenSet[_S]]) -> FrozenSet[Union[_T, _S]]: ...
def __xor__(self, s: Union[Set[_S], FrozenSet[_S]]) -> FrozenSet[Union[_T, _S]]: ...
class slice: pass
class range(Iterable[int]):
def __init__(self, x: int, y: int = ..., z: int = ...) -> None: pass
def __iter__(self) -> Iterator[int]: pass
def __len__(self) -> int: pass
def __next__(self) -> int: pass
class map(Iterator[_S]):
def __init__(self, func: Callable[[_T], _S], iterable: Iterable[_T]) -> None: pass
def __iter__(self) -> Self: pass
def __next__(self) -> _S: pass
class property:
def __init__(self, fget: Optional[Callable[[Any], Any]] = ...,
fset: Optional[Callable[[Any, Any], None]] = ...,
fdel: Optional[Callable[[Any], None]] = ...,
doc: Optional[str] = ...) -> None: ...
def getter(self, fget: Callable[[Any], Any]) -> property: ...
def setter(self, fset: Callable[[Any, Any], None]) -> property: ...
def deleter(self, fdel: Callable[[Any], None]) -> property: ...
def __get__(self, obj: Any, type: Optional[type] = ...) -> Any: ...
def __set__(self, obj: Any, value: Any) -> None: ...
def __delete__(self, obj: Any) -> None: ...
def fget(self) -> Any: ...
def fset(self, value: Any) -> None: ...
def fdel(self) -> None: ...
class BaseException: pass
class Exception(BaseException):
def __init__(self, message: Optional[str] = None) -> None: pass
class Warning(Exception): pass
class UserWarning(Warning): pass
class TypeError(Exception): pass
class ValueError(Exception): pass
class AttributeError(Exception): pass
class ImportError(Exception): pass
class NameError(Exception): pass
class UnboundLocalError(NameError): pass
class LookupError(Exception): pass
class KeyError(LookupError): pass
class IndexError(LookupError): pass
class RuntimeError(Exception): pass
class UnicodeEncodeError(RuntimeError): pass
class UnicodeDecodeError(RuntimeError): pass
class NotImplementedError(RuntimeError): pass
class ReferenceError(Exception): pass
class StopIteration(Exception):
value: Any
class StopAsyncIteration(Exception):
value: Any
class ArithmeticError(Exception): pass
class ZeroDivisionError(ArithmeticError): pass
class OverflowError(ArithmeticError): pass
class GeneratorExit(BaseException): pass
def any(i: Iterable[_T]) -> bool: pass
def all(i: Iterable[_T]) -> bool: pass
@overload
def sum(i: Iterable[bool]) -> int: pass
@overload
def sum(i: Iterable[_T]) -> _T: pass
@overload
def sum(i: Iterable[_T], start: _T) -> _T: pass
def reversed(object: Sequence[_T]) -> Iterator[_T]: ...
def id(o: object) -> int: pass
# This type is obviously wrong but the test stubs don't have Sized anymore
def len(o: object) -> int: pass
def print(*args: object) -> None: pass
def isinstance(x: object, t: object) -> bool: pass
def iter(i: Iterable[_T]) -> Iterator[_T]: pass
@overload
def next(i: Iterator[_T]) -> _T: pass
@overload
def next(i: Iterator[_T], default: _T) -> _T: pass
def hash(o: object) -> int: ...
def globals() -> Dict[str, Any]: ...
def hasattr(obj: object, name: str) -> bool: ...
def getattr(obj: object, name: str, default: Any = None) -> Any: ...
def setattr(obj: object, name: str, value: Any) -> None: ...
def delattr(obj: object, name: str) -> None: ...
def enumerate(x: Iterable[_T]) -> Iterator[Tuple[int, _T]]: ...
@overload
def zip(x: Iterable[_T], y: Iterable[_S]) -> Iterator[Tuple[_T, _S]]: ...
@overload
def zip(x: Iterable[_T], y: Iterable[_S], z: Iterable[_V]) -> Iterator[Tuple[_T, _S, _V]]: ...
def eval(e: str) -> Any: ...
def abs(x: __SupportsAbs[_T]) -> _T: ...
@overload
def divmod(x: __SupportsDivMod[T_contra, T_co], y: T_contra) -> T_co: ...
@overload
def divmod(x: T_contra, y: __SupportsRDivMod[T_contra, T_co]) -> T_co: ...
@overload
def pow(base: __SupportsPow2[T_contra, T_co], exp: T_contra, mod: None = None) -> T_co: ...
@overload
def pow(base: __SupportsPow3NoneOnly[T_contra, T_co], exp: T_contra, mod: None = None) -> T_co: ...
@overload
def pow(base: __SupportsPow3[T_contra, _M, T_co], exp: T_contra, mod: _M) -> T_co: ...
def sorted(iterable: Iterable[_T]) -> list[_T]: ...
def exit() -> None: ...
def min(x: _T, y: _T) -> _T: ...
def max(x: _T, y: _T) -> _T: ...
def repr(o: object) -> str: ...
def ascii(o: object) -> str: ...
def ord(o: object) -> int: ...
def chr(i: int) -> str: ...
# Dummy definitions.
class classmethod: pass
class staticmethod: pass
NotImplemented: Any = ...