Skip to main content

Run-time type checker for Python

Project description

Build Status Code Coverage Documentation Tidelift

This library provides run-time type checking for functions defined with PEP 484 argument (and return) type annotations, and any arbitrary objects. It can be used together with static type checkers as an additional layer of type safety, to catch type violations that could only be detected at run time.

Three principal ways to do type checking are provided, each with its pros and cons:

  1. The check_type function:

    • like isinstance(), but supports arbitrary type annotations (within limits)

    • can be used as a cast() replacement, but with actual checking of the value

  2. The check_argument_types() and check_return_type() functions:

    • debugger friendly (except when running with the pydev debugger with the C extension installed)

    • does not work reliably with dynamically defined type hints (e.g. in nested functions)

  3. Code instrumentation:

    • entire modules, or individual functions (via @typechecked) are recompiled, with type checking code injected into them

    • automatically checks function arguments, return values and assignments to annotated local variables

    • for generator functions (regular and async), checks yield and send values

    • requires the original source code of the instrumented module(s) to be accessible

Two options are provided for code instrumentation:

  1. the @typechecked function:

    • can be applied to functions individually

  2. the import hook (typeguard.install_import_hook()):

    • automatically instruments targeted modules on import

    • no manual code changes required in the target modules

    • requires the import hook to be installed before the targeted modules are imported

    • may clash with other import hooks

See the documentation for further information.

Project details


Release history Release notifications | RSS feed

Download files

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

Source Distribution

typeguard-4.5.0.tar.gz (80.0 kB view details)

Uploaded Source

Built Distribution

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

typeguard-4.5.0-py3-none-any.whl (36.7 kB view details)

Uploaded Python 3

File details

Details for the file typeguard-4.5.0.tar.gz.

File metadata

  • Download URL: typeguard-4.5.0.tar.gz
  • Upload date:
  • Size: 80.0 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for typeguard-4.5.0.tar.gz
Algorithm Hash digest
SHA256 749bea21cdb2553e12831bc29f1eae980b22c7de8331ab67ae7db9e85470b5a7
MD5 79a61cab4cc68c484f7b3ccdebb52fdd
BLAKE2b-256 7eecadfe3dd6b5f7c5fc0b3cecdf6f893f1756dbd23cf749cd1ae49db069414f

See more details on using hashes here.

Provenance

The following attestation bundles were made for typeguard-4.5.0.tar.gz:

Publisher: publish.yml on agronholm/typeguard

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file typeguard-4.5.0-py3-none-any.whl.

File metadata

  • Download URL: typeguard-4.5.0-py3-none-any.whl
  • Upload date:
  • Size: 36.7 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for typeguard-4.5.0-py3-none-any.whl
Algorithm Hash digest
SHA256 cfda388fc88a9ce42a41890900d6f31ee124bea9b73bb84701a32438e92165c3
MD5 e2086748cd000e6439c8b91a30ff051d
BLAKE2b-256 d4357541d1f046491fac8ce05d543d3f0de0af02086ad864dd3a23535ec703b9

See more details on using hashes here.

Provenance

The following attestation bundles were made for typeguard-4.5.0-py3-none-any.whl:

Publisher: publish.yml on agronholm/typeguard

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

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