- Notifications
You must be signed in to change notification settings - Fork117
Run-time type checker for Python
License
NotificationsYou must be signed in to change notification settings
agronholm/typeguard
Folders and files
Name | Name | Last commit message | Last commit date | |
---|---|---|---|---|
Repository files navigation
This library provides run-time type checking for functions defined withPEP 484 argument (and return) typeannotations, and any arbitrary objects. It can be used together with static typecheckers as an additional layer of type safety, to catch type violations that could onlybe 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
- like
- Code instrumentation:
- entire modules, or individual functions (via
@typechecked
) are recompiled, withtype checking code injected into them - automatically checks function arguments, return values and assignments to annotatedlocal 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
- entire modules, or individual functions (via
Two 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 hooks
See thedocumentation for further information.
About
Run-time type checker for Python
Resources
License
Stars
Watchers
Forks
Packages0
No packages published