Reified generics in Python to get type parameters at runtime
Project description
Reification (Python library)
Reified generics in Python to get type parameters at runtime
from reification import Reified
class ReifiedList[T](Reified, list[T]):
pass
xs = ReifiedList[int](range(10))
print(xs) # [0, 1, 2, 3, 4, 5, 6, 7, 8, 9]
print(xs.targ) # <class 'int'>
See the detailed documentation at https://curegit.github.io/reification/.
Requirements
- Python >= 3.12
This library is written in pure Python and does not require any external modules.
Installation
pip install reification
Example Usage: Type-Checked Generic Stack
from reification import Reified
class ReifiedStack[T](Reified):
def __init__(self) -> None:
super().__init__()
self.items: list[T] = []
def push(self, item: T) -> None:
# We can do runtime check
if isinstance(item, self.targ):
self.items.append(item)
else:
raise TypeError()
def pop(self) -> T:
if self.items:
return self.items.pop()
else:
raise IndexError("pop from empty stack")
stack = ReifiedStack[str]()
stack.push("spam") # OK
stack.push(42) # raises TypeError
The ReifiedStack class created here is generic and derived from the Reified base class, and implements a simple stack with push and pop methods.
In the push method, we are checking at runtime if the item being pushed is of the specified generic type (this type is accessible via the targ attribute inherited from Reified).
If the type of the item does not match, a TypeError is raised.
In the example usage, we create an instance of the ReifiedStack class with str as the type argument. When we try to push a string "spam", the item is accepted since it matches the stack's specified type argument.
However, when we try to push an integer 42, a TypeError is raised because the type of the item does not match the stack's type argument.
This demonstrates the use of reified generics in Python where we can have runtime access to the type parameters, enabling us to type check dynamically at runtime. This is useful in situations where we need to enforce type safety in our code or use type information at runtime.
API
See the full API reference at https://curegit.github.io/reification/reference/.
License
WTFPL
Copyright (C) 2023 curegit
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
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file reification-1.2.1.tar.gz.
File metadata
- Download URL: reification-1.2.1.tar.gz
- Upload date:
- Size: 7.2 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.14.3
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
3487dc164e6961916d80de9778be6f38077a087b9d365cea35cca6dff8cbd836
|
|
| MD5 |
00e6e6c0398c92856e3eb0ee1bf2c597
|
|
| BLAKE2b-256 |
b843295910b49452154e178f8b575851e10ab856a4d4fc6d4f3e87be96e1bec0
|
File details
Details for the file reification-1.2.1-py3-none-any.whl.
File metadata
- Download URL: reification-1.2.1-py3-none-any.whl
- Upload date:
- Size: 5.0 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.14.3
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
3749e1ae97a8127ab6fcd3612df1dbdd0e66c1c34c72cd24f7f19f82fa1938e5
|
|
| MD5 |
df43d8e9dd2ba04b9f1efe51a289e9f1
|
|
| BLAKE2b-256 |
fa0d48cefd5d8666e1525aed876f7d7e9a0b15f1328bb0528c84d26b8ab94610
|