50 lines
1.3 KiB
Python
50 lines
1.3 KiB
Python
# Copyright 2009-2024 Joshua Bronson. All rights reserved.
|
|
#
|
|
# This Source Code Form is subject to the terms of the Mozilla Public
|
|
# License, v. 2.0. If a copy of the MPL was not distributed with this
|
|
# file, You can obtain one at http://mozilla.org/MPL/2.0/.
|
|
|
|
|
|
"""Provide typing-related objects."""
|
|
|
|
from __future__ import annotations
|
|
|
|
import typing as t
|
|
from enum import Enum
|
|
|
|
|
|
KT = t.TypeVar('KT')
|
|
VT = t.TypeVar('VT')
|
|
VT_co = t.TypeVar('VT_co', covariant=True)
|
|
|
|
|
|
Items = t.Iterable[t.Tuple[KT, VT]]
|
|
|
|
|
|
@t.runtime_checkable
|
|
class Maplike(t.Protocol[KT, VT_co]):
|
|
"""Like typeshed's SupportsKeysAndGetItem, but usable at runtime."""
|
|
|
|
def keys(self) -> t.Iterable[KT]: ...
|
|
|
|
def __getitem__(self, __key: KT) -> VT_co: ...
|
|
|
|
|
|
MapOrItems = t.Union[Maplike[KT, VT], Items[KT, VT]]
|
|
MappOrItems = t.Union[t.Mapping[KT, VT], Items[KT, VT]]
|
|
ItemsIter = t.Iterator[t.Tuple[KT, VT]]
|
|
|
|
|
|
class MissingT(Enum):
|
|
"""Sentinel used to represent none/missing when None itself can't be used."""
|
|
|
|
MISSING = 'MISSING'
|
|
|
|
|
|
MISSING: t.Final[t.Literal[MissingT.MISSING]] = MissingT.MISSING
|
|
OKT = t.Union[KT, MissingT] #: optional key type
|
|
OVT = t.Union[VT, MissingT] #: optional value type
|
|
|
|
DT = t.TypeVar('DT') #: for default arguments
|
|
ODT = t.Union[DT, MissingT] #: optional default arg type
|