Skip to main content

No project description provided

Project description

typeapi

Python

Compatibility: Python 3.6.3+

The typeapi package provides an object-oriented interface for introspecting PEP484 type hints at runtime, including forward references that make use of the more recent PEP585 and PEP604 type hint features in Python versions that don't natively support them.

The following kinds of type hints are currently supported:

Concrete type Description Added in
ClassTypeHint For any normal or generic type as well as typing.Any. Provides access to the underlying type, the type arguments and parameters, if any. 1.0.0
UnionTypeHint Represents Union type hint and gives access to the union members. 1.0.0
LiteralTypeHint Represents a Literal type hint and gives access to the literal values. 1.0.0
AnnotatedTypeHint Represents an Annotated type hint and gives access to the annotated type as well as the metadata. 1.0.0
TypeVarTypeHint Represents a TypeVar type hint and gives an interface to access the variable's metadata (such as constarints, variance, ...). 1.0.0
ForwardRefTypeHint Represents a forward reference. Can be evaluated in Python 3.6+ even if it contains PEP585 and PEP604 expressions. 1.0.0, future support in 1.3.0
TupleTypeHint Reperesents a Tuple type hint, allowing you to differentiate between repeated and explicitly sized tuples. 1.2.0

The main entry point to wrapping a low-level type hint is the TypeHint() constructor.

Examples

Inspect a List[int] type hint:

# cat <<EOF | python -
from typeapi import ClassTypeHint, TypeHint
from typing import List

hint = TypeHint(List[int])
assert isinstance(hint, ClassTypeHint)
assert hint.type is list

item_hint = hint[0]
assert isinstance(item_hint, ClassTypeHint)
assert item_hint.type is int

Retrieve the metadata from an Annotated[...] type hint:

# cat <<EOF | python -
from typeapi import AnnotatedTypeHint, ClassTypeHint, TypeHint
from typing_extensions import Annotated

hint = TypeHint(Annotated[int, 42])
assert isinstance(hint, AnnotatedTypeHint)
assert hint.type is int
assert hint.metadata == (42,)

sub_hint = hint[0]
assert isinstance(sub_hint, ClassTypeHint)
assert sub_hint.type is int

Parameterize one type hint with the parameterization of a generic alias:

# cat <<EOF | python -
from dataclasses import dataclass
from typeapi import ClassTypeHint, TypeHint
from typing import Generic, TypeVar
from typing_extensions import Annotated

T = TypeVar("T")

@dataclass
class MyGeneric(Generic[T]):
  value: T

hint = TypeHint(MyGeneric[int])
assert isinstance(hint, ClassTypeHint)
assert hint.get_parameter_map() == {T: int}

member_hint = TypeHint(T).parameterize(hint.get_parameter_map())
assert isinstance(member_hint, ClassTypeHint)
assert member_hint.type is int

Evaluate forward references:

# cat <<EOF | python -
from typeapi import ClassTypeHint, ForwardRefTypeHint, TypeHint

MyVector = "list[MyType]"

class MyType:
  pass

hint = TypeHint(MyVector).evaluate(globals())
print(hint)  # TypeHint(typing.List[__main__.MyType])
assert isinstance(hint, ClassTypeHint)
assert hint.type is list

item_hint = hint[0]
assert isinstance(item_hint, ClassTypeHint)
assert item_hint.type is MyType

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

typeapi-1.3.1.tar.gz (18.2 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

typeapi-1.3.1-py3-none-any.whl (19.2 kB view details)

Uploaded Python 3

File details

Details for the file typeapi-1.3.1.tar.gz.

File metadata

  • Download URL: typeapi-1.3.1.tar.gz
  • Upload date:
  • Size: 18.2 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.8.0 pkginfo/1.8.3 readme-renderer/37.2 requests/2.28.1 requests-toolbelt/0.10.0 urllib3/1.26.12 tqdm/4.64.1 importlib-metadata/5.0.0 keyring/23.9.3 rfc3986/2.0.0 colorama/0.4.5 CPython/3.10.4

File hashes

Hashes for typeapi-1.3.1.tar.gz
Algorithm Hash digest
SHA256 7b090a510bf8a94d7641448295614cedb510996ef1a2e53be4ad73a60bbf25d4
MD5 edfba204be6a999f2abbb231a174c6dc
BLAKE2b-256 9c43f20e4523aafbc33ffb102e8d57d2c41e984e9c0d55eae2d9d2c2e9ed420b

See more details on using hashes here.

File details

Details for the file typeapi-1.3.1-py3-none-any.whl.

File metadata

  • Download URL: typeapi-1.3.1-py3-none-any.whl
  • Upload date:
  • Size: 19.2 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.8.0 pkginfo/1.8.3 readme-renderer/37.2 requests/2.28.1 requests-toolbelt/0.10.0 urllib3/1.26.12 tqdm/4.64.1 importlib-metadata/5.0.0 keyring/23.9.3 rfc3986/2.0.0 colorama/0.4.5 CPython/3.10.4

File hashes

Hashes for typeapi-1.3.1-py3-none-any.whl
Algorithm Hash digest
SHA256 c72840ca79b1bcf67434cf53ff2f840944d4a3a74ebc9f403d22c4a5e321b8c2
MD5 cd1fb758b26bc411f316250c5243db72
BLAKE2b-256 2e795650e1f89d8f3d1b6bbf5081682db91fc2765648cfc6e413f023ef68872b

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page