Skip to main content

Reified generics in Python to get type parameters at runtime

Project description

Reification (Python library)

Unit Tests

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


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

reification-1.2.1.tar.gz (7.2 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

reification-1.2.1-py3-none-any.whl (5.0 kB view details)

Uploaded Python 3

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

Hashes for reification-1.2.1.tar.gz
Algorithm Hash digest
SHA256 3487dc164e6961916d80de9778be6f38077a087b9d365cea35cca6dff8cbd836
MD5 00e6e6c0398c92856e3eb0ee1bf2c597
BLAKE2b-256 b843295910b49452154e178f8b575851e10ab856a4d4fc6d4f3e87be96e1bec0

See more details on using hashes here.

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

Hashes for reification-1.2.1-py3-none-any.whl
Algorithm Hash digest
SHA256 3749e1ae97a8127ab6fcd3612df1dbdd0e66c1c34c72cd24f7f19f82fa1938e5
MD5 df43d8e9dd2ba04b9f1efe51a289e9f1
BLAKE2b-256 fa0d48cefd5d8666e1525aed876f7d7e9a0b15f1328bb0528c84d26b8ab94610

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page