Skip to main content

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

Project description

class_singledispatch Package version Supported Python versions

Tests Coverage Poetry Ruff Code style License Pre-commit

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

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

A simple example

Use functools.singledispatch to singledispatch classes as parameters.

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, as soon as `@class_singledispatch` allows specifying
# the class similarly to `.register` -- 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

If you want to…

…use this tool in your project 💻

You might simply install it with pip:

pip install class-singledispatch

If you use Poetry, then run:

poetry add class-singledispatch

…contribute to class_singledispatch 🚀

[!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 --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

class_singledispatch-1.0.2.tar.gz (6.1 kB view details)

Uploaded Source

Built Distribution

class_singledispatch-1.0.2-py3-none-any.whl (5.8 kB view details)

Uploaded Python 3

File details

Details for the file class_singledispatch-1.0.2.tar.gz.

File metadata

  • Download URL: class_singledispatch-1.0.2.tar.gz
  • Upload date:
  • Size: 6.1 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/4.0.2 CPython/3.11.7

File hashes

Hashes for class_singledispatch-1.0.2.tar.gz
Algorithm Hash digest
SHA256 ae9e18eb37f6f8c8ef6d86f3a55e67e495002116171335a841363bc6837f2aae
MD5 a48bfb33a14cc655076a444bf0590bb8
BLAKE2b-256 889a26feb8dc9db5118b1276c57f084b1e74de070f4780d3d53534c7d7c9ceee

See more details on using hashes here.

File details

Details for the file class_singledispatch-1.0.2-py3-none-any.whl.

File metadata

File hashes

Hashes for class_singledispatch-1.0.2-py3-none-any.whl
Algorithm Hash digest
SHA256 2c2e31123ebf114f64902495ad2c1ddb0bb1248c46ce06a40c9a7a7daafd8470
MD5 ad6055ab8ed305a5b466d6bfa1dd8cb6
BLAKE2b-256 e3b676385d94d7e2e75f56df042ec76a908a40be70e5653729624f408b733299

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