Easy declaration of data structures with runtime type checking
Project description
easytypes
Easy typed structures for Python with optional field checking and runtime type checking. Based on class decorators and typeguard
package for type checking.
What does the package implement
from easytypes import easy_type_decorator, safe_type, fast_type, unlimited_type
from easytypes import EasyTypesException
from easytypes import AttributeRequired, AttributeNotAllowed, AttributeTypeError
from easytypes import Required
from easytypes import disable_all_checks, enable_all_checks
How to define a simple data class
from easytypes import easy_type_decorator, safe_type, fast_type, unlimited_type
from easytypes import EasyTypesException
from easytypes import AttributeRequired, AttributeNotAllowed, AttributeTypeError
from easytypes import Required
from easytypes import disable_all_checks, enable_all_checks
@safe_type # You cannot: add new attrs; not set (or delete) the required attrs; assign wrong types
class A:
a: int # Type checking, not required, no default value
b: str = '5' # Type checking, not required, the default value is '5'
c: float = Required() # Type checking, required, no default value
d: Tuple[int, int] = Required(2, 3) # Type checking, required, the default value is (2, 3)
...and how does the class work
va = A(a=2, b='b', c=1.0, d=(2,4)) # Ok
assert va.a == 2
va.a = 5
assert va.a == 5
va = A(c=1.0) # Ok, using default values
va = A(c=1.0, q=2) # raises AttributeNotAllowed
va.q = 0 # raises AttributeNotAllowed
va.a = '5' # raises AttributeTypeError (a should be int)
va = A(c='c') # raises AttributeTypeError (c should be float)
va = (b='c') # raises AttributeRequired (a is missing)
How to extend a class
@safe_type
class B(A):
e: str = 5 # Is added to the fields defined in A
...and how to redefine a field
@safe_type
class C(A):
a: int = 5 # Not recomended and not prohibited
How to disable all the checks at runtime
disable_all_checks() # Does not affect all the previously created classes, so put it before the class declaration
...and how to re-enable them
enable_all_checks() # Does not affect all the previously created classes, so put it before the class declaration
The other class decorators
unlimited_type # Allows to add the attributes that are not declared at the class level
fast_type # No checks at all, just a constructor implemetation accepting the attributes
...and how to get a customized decorator
easy_type_decorator(chk_required=True, chk_allowed=True, chk_types=True) # Allows to activate only the desired checks
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
easytypes-0.5.2.tar.gz
(7.8 kB
view details)
Built Distribution
File details
Details for the file easytypes-0.5.2.tar.gz
.
File metadata
- Download URL: easytypes-0.5.2.tar.gz
- Upload date:
- Size: 7.8 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/4.0.1 CPython/3.11.3
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 0b0c93fe0744d829da0ce68c543fa766892f65440b46f78b9292f37c4e4821e5 |
|
MD5 | fbdb45edf777175c26e532ed638d9848 |
|
BLAKE2b-256 | a197fadb8f74471ea09ac38fc0c24e0571ea634ccc2235858b58720d7c131de5 |
File details
Details for the file easytypes-0.5.2-py3-none-any.whl
.
File metadata
- Download URL: easytypes-0.5.2-py3-none-any.whl
- Upload date:
- Size: 9.0 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/4.0.1 CPython/3.11.3
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 2a352f60a4deabd40691e684b31b2af19084c895052bacf6b15ab3f75e889014 |
|
MD5 | 4052c6c2a69db779d53c475549da62cd |
|
BLAKE2b-256 | 061442b5f778a2000361dd897bf516512c2cafe8251fc5f464b602e4529fd475 |