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 for simplicity and speed. With caching of argument types, it 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.

Multimethods are implemented as mappings from signatures to functions, and can be introspected as such.

method[type,...]           # get registered function
method[type,...] = func    # register function by explicit types
method.register(func)      # decorator to register annotated function (with any __name__)

The functools.singledispatch style syntax introduced in Python 3.4 is also supported. This requires creating a multidispatch object explicitly, and consequently doesn’t rely on the name matching. The register method returns a decorator for given types, thereby supporting Python 2 and stacking of multiple signatures.

from multimethod import multidispatch

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

@func.register(object, int)
@func.register(int, object)
def _(*args):
   ...

Overloads dispatch on annotated predicates (Python >=3.5 required). Each predicate is checked in the reverse order of registration.

The implementation is separate from multimethod due to the different performance characteristics. Instead a simple isa predicate is provided for checking instance type.

from multimethod import overload

@overload
def func(obj):
   # optional base implementation, i.e., no annotations always match

@overload
def func(obj: isa(str)):
   ...

@overload
def func(obj: str.isdigit):
   ...

See tests for more example usage.

Installation

$ pip install multimethod

Dependencies

  • Python ~=2.7, >=3.4

Tests

100% branch coverage.

$ pytest [--cov]

Changes

0.7

  • Forward references allowed in type hints

  • Register method

  • Overloads with predicate dispatch

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.7.tar.gz (6.6 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.7-py2.py3-none-any.whl (7.1 kB view details)

Uploaded Python 2Python 3

File details

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

File metadata

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

File hashes

Hashes for multimethod-0.7.tar.gz
Algorithm Hash digest
SHA256 5748e620aa50d95843b0fda0e47cd616227df8ff58bafdeae9393852a93a5d47
MD5 ea9056e87834f5c6cf6c138cae4f0252
BLAKE2b-256 5c29f8b101ed29ac77e7298b57600550c8f211e02179785581eff7d0a6728a41

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for multimethod-0.7-py2.py3-none-any.whl
Algorithm Hash digest
SHA256 0c0efff31315fd5f9716e68c6b94955187462ae0a5861a7494f51dc63081c052
MD5 a1a92b345184c5ae0bf94d619ddacd96
BLAKE2b-256 29e88c1c31b246a1434d7860936a49dd2e7e74f6fb5f169b6e288308b3f37adf

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