Skip to main content

A ``singledispatch()`` for arguments that are classes annotated as specific types.

Project description

class_singledispatch
skeleton Supported Python versions Package version

Tests Coverage Documentation Status

A singledispatch() for arguments that are classes annotated as specific types.

Inspired by https://github.com/python/cpython/issues/100623.

A Simple Example

While functools.singledispatch examines the class of the first user argument, class_singledispatch uses the first argument as the class itself and performs the same task with it as functools.singledispatch.

from class_singledispatch import class_singledispatch


class T:
    pass


class OtherT:
    pass


@class_singledispatch
def on_class(cls: type[T], /) -> None:
    print("T!")


@on_class.register
def on_other_class(cls: type[OtherT], /) -> None:
    print("OtherT!")


# Useful for <3.10 without eval_type_backport -- pass the class to the decorator
# not to use the annotation from the function for the targeted class resolution
@on_class.register(SomeOtherT)
def on_some_other_class(cls: type[SomeOtherT], /) -> None:
    print("SomeOtherT!")


on_class(T)  # T!
on_class(OtherT)  #  OtherT!
on_class(SomeOtherT)  #  SomeOtherT!

Installation

You might simply install it with pip:

pip install class-singledispatch

[!Note] class-singledispatch supports modern type hinting.
To use PEP 585 or PEP 604 annotations on Python <3.10, install class-singledispatch[modern-type-hints].

If you use Poetry, then you might want to run:

poetry add class-singledispatch

For Contributors

Poetry Ruff Pre-commit

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

  1. Fork the class_singledispatch repository on GitHub.

  2. Install Poetry.
    Poetry is an amazing tool for managing dependencies & virtual environments, building packages and publishing them. You might use pipx to install it globally (recommended):

    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/class_singledispatch path/to/class_singledispatch
    cd path/to/class_singledispatch
    poetry env use $(cat .python-version)
    poetry install
    

    Next up, simply activate the virtual environment and install pre-commit hooks:

    poetry shell
    pre-commit install
    

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

class_singledispatch-1.2.3.post1.tar.gz (6.6 kB view details)

Uploaded Source

Built Distribution

File details

Details for the file class_singledispatch-1.2.3.post1.tar.gz.

File metadata

File hashes

Hashes for class_singledispatch-1.2.3.post1.tar.gz
Algorithm Hash digest
SHA256 af0c3ec52a2c67dbd6ad2dbcd44dbad5eac6eec0ad7edbbdb8555a6a3b25268b
MD5 7a0c17c4d4195901e7fde9071b8d5297
BLAKE2b-256 2ec2c541379fc2742a0f9ad4db116ba9d19c3607d0a6a69e0ef3f86bfcdca072

See more details on using hashes here.

File details

Details for the file class_singledispatch-1.2.3.post1-py3-none-any.whl.

File metadata

File hashes

Hashes for class_singledispatch-1.2.3.post1-py3-none-any.whl
Algorithm Hash digest
SHA256 da093b457680ac02ca0cd20b0fb5fb3a8d1daa11c6b7edea14c56e73a9022876
MD5 c864976f1713e9e25279e1cf585a9d96
BLAKE2b-256 c5a3cff004d2d3a0578404a963779fef920dd6ff7dbfdbdc637fe62c503813e7

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