import abc from collections.abc import Iterable, Mapping, MutableMapping from typing import TYPE_CHECKING, Protocol, TypeVar, Union, overload if TYPE_CHECKING: from ._multidict_py import istr else: istr = str _V = TypeVar("_V") _V_co = TypeVar("_V_co", covariant=True) _T = TypeVar("_T") class SupportsKeys(Protocol[_V_co]): def keys(self) -> Iterable[str]: ... def __getitem__(self, key: str, /) -> _V_co: ... class SupportsIKeys(Protocol[_V_co]): def keys(self) -> Iterable[istr]: ... def __getitem__(self, key: istr, /) -> _V_co: ... MDArg = Union[SupportsKeys[_V], SupportsIKeys[_V], Iterable[tuple[str, _V]], None] class MultiMapping(Mapping[str, _V_co]): @overload def getall(self, key: str) -> list[_V_co]: ... @overload def getall(self, key: str, default: _T) -> Union[list[_V_co], _T]: ... @abc.abstractmethod def getall(self, key: str, default: _T = ...) -> Union[list[_V_co], _T]: """Return all values for key.""" @overload def getone(self, key: str) -> _V_co: ... @overload def getone(self, key: str, default: _T) -> Union[_V_co, _T]: ... @abc.abstractmethod def getone(self, key: str, default: _T = ...) -> Union[_V_co, _T]: """Return first value for key.""" class MutableMultiMapping(MultiMapping[_V], MutableMapping[str, _V]): @abc.abstractmethod def add(self, key: str, value: _V) -> None: """Add value to list.""" @abc.abstractmethod def extend(self, arg: MDArg[_V] = None, /, **kwargs: _V) -> None: """Add everything from arg and kwargs to the mapping.""" @overload def popone(self, key: str) -> _V: ... @overload def popone(self, key: str, default: _T) -> Union[_V, _T]: ... @abc.abstractmethod def popone(self, key: str, default: _T = ...) -> Union[_V, _T]: """Remove specified key and return the corresponding value.""" @overload def popall(self, key: str) -> list[_V]: ... @overload def popall(self, key: str, default: _T) -> Union[list[_V], _T]: ... @abc.abstractmethod def popall(self, key: str, default: _T = ...) -> Union[list[_V], _T]: """Remove all occurrences of key and return the list of corresponding values."""