Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/agronholm/typeguard
Run-time type checker for Python
https://github.com/agronholm/typeguard
Last synced: 5 days ago
JSON representation
Run-time type checker for Python
- Host: GitHub
- URL: https://github.com/agronholm/typeguard
- Owner: agronholm
- License: other
- Created: 2015-12-27T23:15:37.000Z (about 9 years ago)
- Default Branch: master
- Last Pushed: 2025-01-06T18:20:59.000Z (13 days ago)
- Last Synced: 2025-01-07T01:14:54.078Z (12 days ago)
- Language: Python
- Size: 733 KB
- Stars: 1,573
- Watchers: 21
- Forks: 116
- Open Issues: 29
-
Metadata Files:
- Readme: README.rst
- Contributing: docs/contributing.rst
- License: LICENSE
Awesome Lists containing this project
- best-of-python-dev - GitHub - 6% open · ⏱️ 27.05.2024): (Type checkers)
- awesome-python-typing - typeguard - Another one runtime type checker. (Dynamic type checkers)
README
.. image:: https://github.com/agronholm/typeguard/actions/workflows/test.yml/badge.svg
:target: https://github.com/agronholm/typeguard/actions/workflows/test.yml
:alt: Build Status
.. image:: https://coveralls.io/repos/agronholm/typeguard/badge.svg?branch=master&service=github
:target: https://coveralls.io/github/agronholm/typeguard?branch=master
:alt: Code Coverage
.. image:: https://readthedocs.org/projects/typeguard/badge/?version=latest
:target: https://typeguard.readthedocs.io/en/latest/?badge=latest
:alt: DocumentationThis 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.Two principal ways to do type checking are provided:
#. 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
#. 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 accessibleTwo options are provided for code instrumentation:
#. the ``@typechecked`` function:
* can be applied to functions individually
#. 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 hooksSee the documentation_ for further information.
.. _documentation: https://typeguard.readthedocs.io/en/latest/