Descriptor classes for typed attributes and properties.
Project description
typed-descriptors is a small library of descriptor classes featuring static and runtime typechecking, runtime validation, and other useful features.
Static typechecking is compatible with PEP 484 type hints, and runtime typechecking is performed by the typing-validation library.
Install
You can install the latest release from PyPI as follows:
pip install --upgrade typed-descriptors
Usage
Classes from the typed_descriptors module can be used to create statically typechecked descriptors which implement the following features:
attributes with runtime typechecking on write
attributes with validation on write
readonly attributes (set once)
cached properties
Typechecking is compatible with PEP 484 type hints. Runtime typechecking is performed by the typing-validation library.
Below is a simple example displaying all features listed above:
from collections.abc import Sequence
import networkx as nx # type: ignore
from typed_descriptors import Attr, Prop
class LabelledKn:
r"""
A complete graph :math:`K_n` with readonly size and mutable labels,
where the NetworkX graph object is computed lazily and cached.
"""
n = Attr(int, lambda self, n: n >= 0, readonly=True)
# type ^^^ validation ^^^^^^ ^^^^^^^^^^^^^ attribute is readonly
labels = Attr(Sequence[str], lambda self, labels: len(labels) == self.n)
# type ^^^^^^^^^^^^^ validation ^^^^^^^^^^^^^^^^^^^^^
graph = Prop(nx.Graph, lambda self: nx.complete_graph(self.n))
# type ^^^^^^^^ prop value ^^^^^^^^^^^^^^^^^^^^^^^^^
def __init__(self, n: int, labels: Sequence[int]):
# Setters for Attr instances take care of runtime typechecking and validation
# for the arguments 'n' and 'labels' which have been passed to the constuctor.
self.n = n
self.labels = labels
myobj = LabelledKn(3, ["a", "b", "c"]) # OK
myobj.labels = ("x", "y", "z") # OK
print(myobj.graph.edges) # OK: EdgeView([(0, 1), (0, 2), (1, 2)])
myobj.x = 5 # AttributeError (readonly descriptor)
myobj.y = ["a", "b", "c", "d"] # ValueError (lenght of y is not 3)
myobj.y = 5 # TypeError (type of y is not 'Sequence')
myobj.y = [2, 3, 5] # TypeError (type of y is not 'Sequence[str]')
API
For the full API documentation, see https://typed-descriptors.readthedocs.io/
Contributing
Please see CONTRIBUTING.md.
License
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
Built Distribution
File details
Details for the file typed-descriptors-1.2.1.post3.tar.gz
.
File metadata
- Download URL: typed-descriptors-1.2.1.post3.tar.gz
- Upload date:
- Size: 763.5 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/4.0.2 CPython/3.12.0
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 96f0a2380eaa97afef2ea30cbc0159fd320d783f00e2a2ddea4865be0437030c |
|
MD5 | 9161f435ffeb325fabb05cc4e886189c |
|
BLAKE2b-256 | c0b60b159a34050e67046ffb3d090d493197e7db1db5760d16ca99ba55b4f0e6 |
File details
Details for the file typed_descriptors-1.2.1.post3-py3-none-any.whl
.
File metadata
- Download URL: typed_descriptors-1.2.1.post3-py3-none-any.whl
- Upload date:
- Size: 15.0 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/4.0.2 CPython/3.12.0
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | e03637ad0d0ec85c298640b2eccebafd7358d385d682f7605fc8ce2df6544514 |
|
MD5 | f4132c0582a5ad64a89b20345c1dfa91 |
|
BLAKE2b-256 | db84005d30c7d832c37ea531a89f0332b2198683f31b6b46cc524d34ae2e860e |