Skip to main content

Reuse type arguments explicitly passed at runtime to a generic class before instantiating.

Project description

runtime_generics Package version Supported Python versions

Tests Coverage Ruff Code style License Pre-commit

Highly into type-safe Python code?

runtime_generics is a niche Python library that allows you to reuse type arguments explicitly passed at runtime to generic classes before instantiation. The library does two things:

  • makes it possible to retrieve the type argument passed to the generic class at runtime before the class was instantiated;
  • given a parametrized generic class (generic alias), it makes every class method use generic alias cls instead of the origin class.

Simple example

3.12+ (PEP 695 syntax):

from runtime_generics import runtime_generic, select

@runtime_generic
class MyGeneric[T]:
    type_argument: type[T]

    def __init__(self) -> None:
        self.type_argument = select[T](self)

    @classmethod
    def whoami(cls):
        print(f"I am {cls}")

my_generic = MyGeneric[int]()
assert my_generic.type_argument is int
my_generic.whoami()  # I am MyGeneric[int]

3.8+:

from __future__ import annotations

from typing import Generic, TypeVar
from runtime_generics import runtime_generic, select

T = TypeVar("T")

@runtime_generic
class MyGeneric(Generic[T]):
    type_argument: type[T]

    def __init__(self) -> None:
        self.type_argument = select[T](self)

    @classmethod
    def whoami(cls):
        print(f"I am {cls}")

my_generic = MyGeneric[int]()
assert my_generic.type_argument is int
my_generic.whoami()  # I am MyGeneric[int]

Installation

If you want to…

…use this tool in your project 💻

You might simply install it with pip:

pip install runtime-generics

If you use Poetry, then run:

poetry add runtime-generics

…contribute to runtime_generics 🚀

[!Note] If you use Windows, it is highly recommended to complete the installation in the way presented below through WSL2.

  1. Fork the runtime_generics repository on GitHub.

  2. Install Poetry.
    Poetry is an amazing tool for managing dependencies & virtual environments, building packages and publishing them.

    pipx install poetry
    

    If you encounter any problems, refer to the official documentation for the most up-to-date installation instructions.

    Be sure to have Python 3.8 installed—if you use pyenv, simply run:

    pyenv install 3.8
    
  3. Clone your fork locally and install dependencies.

    git clone https://github.com/your-username/runtime_generics path/to/runtime_generics
    cd path/to/runtime_generics
    poetry env use $(cat .python-version)
    poetry install
    poetry shell
    pre-commit install --hook-type pre-commit --hook-type pre-push
    

For more information on how to contribute, check out CONTRIBUTING.md.
Always happy to accept contributions! ❤️

Legal info

© Copyright by Bartosz Sławecki (@bswck).
This software is licensed under the terms of MIT License.

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

runtime_generics-1.2.0.tar.gz (7.7 kB view details)

Uploaded Source

Built Distribution

runtime_generics-1.2.0-py3-none-any.whl (7.6 kB view details)

Uploaded Python 3

File details

Details for the file runtime_generics-1.2.0.tar.gz.

File metadata

  • Download URL: runtime_generics-1.2.0.tar.gz
  • Upload date:
  • Size: 7.7 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/4.0.2 CPython/3.11.6

File hashes

Hashes for runtime_generics-1.2.0.tar.gz
Algorithm Hash digest
SHA256 daa76e5849a1d39a3c3ffb321092bd34683c63b076cb49f8fa94a8e6fc85039a
MD5 738710756f650c368e2f2ccdbfac9005
BLAKE2b-256 5398fd748a61ecfb35e2874205e2d1a8b7746eb2cfc6e218b7bf7566639bd0d8

See more details on using hashes here.

File details

Details for the file runtime_generics-1.2.0-py3-none-any.whl.

File metadata

File hashes

Hashes for runtime_generics-1.2.0-py3-none-any.whl
Algorithm Hash digest
SHA256 120eb530cc16a1527a2889c90279259d79d6a6bdd21bada5ec857e2649e56176
MD5 104067d29bd8e354a78085d4321033ab
BLAKE2b-256 1db1e1892ecd394ca37b3edc78e78db655fd00f2bd159b28c7488f626bda1f02

See more details on using hashes here.

Supported by

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