Skip to main content

Multiple argument dispatching.

Project description

https://img.shields.io/pypi/v/multimethod.svg https://img.shields.io/pypi/pyversions/multimethod.svg https://img.shields.io/pypi/status/multimethod.svg https://img.shields.io/travis/coady/multimethod.svg https://img.shields.io/codecov/c/github/coady/multimethod.svg

Multimethod provides a decorator for adding multiple argument dispatching to functions. The decorator finds the multimethod of the same name, creating it if necessary, and registers the function with its annotations.

There are several multiple dispatch libraries on PyPI. This one aims to be correct, simple, and fast. It doesn’t support arbitrary predicates, for example, but should be the fastest pure Python implementation possible.

Usage

from multimethod import multimethod

@multimethod
def func(x: int, y: float):
   ...

func is now a multimethod which will delegate to the above function, when called with arguments of the specified types. Subsequent usage will register new types and functions to the existing multimethod of the same name. If an exact match can’t be found, the next closest method is called (and cached). Candidate methods are ranked based on their subclass relationships. If no matches are found, a custom TypeError is raised.

A strict flag can also be set on the multimethod object, in which case finding multiple matches also raises a TypeError. Keyword arguments can be used when calling, but won’t affect the dispatching.

Types can instead be specified by calling multimethod, thereby supporting Python 2 as well. This syntax also supports stacking decorators for registering multiple signatures.

@multimethod(int, float)
@multimethod(float, int)
def func(x, y):
   ...

The functools.singledispatch style syntax introduced in Python 3.4 is also supported. This requires creating a multimethod explicitly, and consequently doesn’t rely on the name matching.

from multimethod import multidispatch

@multidispatch
def func(*args):
   ...

@func.register(*types)
def _(*args):
   ...

See tests for more example usage.

Installation

$ pip install multimethod

Dependencies

  • Python 2.7, 3.3+

Tests

100% branch coverage.

$ pytest [--cov]

Changes

0.6

  • Multimethods can be defined inside a class

0.5

  • Optimized dispatching

  • Support for functools.singledispatch syntax

0.4

  • Dispatch on Python 3 annotations

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

multimethod-0.6.tar.gz (5.1 kB view details)

Uploaded Source

Built Distribution

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

multimethod-0.6-py2.py3-none-any.whl (5.9 kB view details)

Uploaded Python 2Python 3

File details

Details for the file multimethod-0.6.tar.gz.

File metadata

  • Download URL: multimethod-0.6.tar.gz
  • Upload date:
  • Size: 5.1 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No

File hashes

Hashes for multimethod-0.6.tar.gz
Algorithm Hash digest
SHA256 8bcd126f109ba22bcfa32053f0b56c6676204e241df0907198cbaf62326f1c7c
MD5 db4f0bf1bf2497e764ea99ddcabdf22a
BLAKE2b-256 23a9b463846378a17efcacc5e2bd5189035776a3cb0c00f643a75ffe7beb49c2

See more details on using hashes here.

File details

Details for the file multimethod-0.6-py2.py3-none-any.whl.

File metadata

File hashes

Hashes for multimethod-0.6-py2.py3-none-any.whl
Algorithm Hash digest
SHA256 d6e57443e877b9c565eff107de760029e78c7432286cbad155ae1ec0b918f1dd
MD5 a79b6c7a86614e8eaf1acbb52e38e633
BLAKE2b-256 fff6ac4366395cd56dd562503c795da6fc4ab72a4d23007418c1d5263f1f3193

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