Skip to main content

Specifications for callback functions passed in to an API

Project description

https://travis-ci.org/takluyver/backcall.png?branch=master

Specifications for callback functions passed in to an API

If your code lets other people supply callback functions, it’s important to specify the function signature you expect, and check that functions support that. Adding extra parameters later would break other peoples code unless you’re careful.

backcall provides a way of specifying the callback signature using a prototype function:

from backcall import callback_prototype

@callback_prototype
def handle_ping(sender, delay=None):
    # Specify positional parameters without a default, and keyword
    # parameters with a default.
    pass

def register_ping_handler(callback):
    # This checks and adapts the function passed in:
    callback = handle_ping.adapt(callback)
    ping_callbacks.append(callback)

If the callback takes fewer parameters than your prototype, backcall will wrap it in a function that discards the extra arguments. If the callback expects more arguments, a TypeError is thrown when it is registered.

For more details, see the docs or the Demo notebook.

The tests are run with pytest. In the root directory, execute:

py.test

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

backcall-0.2.0.tar.gz (18.0 kB view details)

Uploaded Source

Built Distribution

backcall-0.2.0-py2.py3-none-any.whl (11.2 kB view details)

Uploaded Python 2 Python 3

File details

Details for the file backcall-0.2.0.tar.gz.

File metadata

  • Download URL: backcall-0.2.0.tar.gz
  • Upload date:
  • Size: 18.0 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: python-requests/2.22.0

File hashes

Hashes for backcall-0.2.0.tar.gz
Algorithm Hash digest
SHA256 5cbdbf27be5e7cfadb448baf0aa95508f91f2bbc6c6437cd9cd06e2a4c215e1e
MD5 1f4c9a370c78743406296f48e56e8821
BLAKE2b-256 a240764a663805d84deee23043e1426a9175567db89c8b3287b5c2ad9f71aa93

See more details on using hashes here.

File details

Details for the file backcall-0.2.0-py2.py3-none-any.whl.

File metadata

  • Download URL: backcall-0.2.0-py2.py3-none-any.whl
  • Upload date:
  • Size: 11.2 kB
  • Tags: Python 2, Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: python-requests/2.22.0

File hashes

Hashes for backcall-0.2.0-py2.py3-none-any.whl
Algorithm Hash digest
SHA256 fbbce6a29f263178a1f7915c1940bde0ec2b2a967566fe1c65c1dfb7422bd255
MD5 4671e998e1853d64a365680de7ecc7a2
BLAKE2b-256 4c1cff6546b6c12603d8dd1070aa3c3d273ad4c07f5771689a7b69a550e8c951

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