File: index.rst

package info (click to toggle)
python-backcall 0.2.0-4
  • links: PTS, VCS
  • area: main
  • in suites: bookworm, forky, sid, trixie
  • size: 168 kB
  • sloc: python: 717; makefile: 145; sh: 8
file content (72 lines) | stat: -rw-r--r-- 2,636 bytes parent folder | download | duplicates (2)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
====================================
Welcome to backcall's documentation!
====================================

.. module:: backcall
   :synopsis: Backwards compatible callback APIs

backcall is a Python module to write backwards compatible callback APIs. That is,
you can add parameters to your calls without breaking third party callback
functions that don't expect those newer parameters. For an example of using it, see the
`Demo notebook <http://nbviewer.ipython.org/github/takluyver/backcall/blob/master/Demo.ipynb>`_.

It can be installed like any other Python package::

    pip install backcall

To use backcall, you first define a 'callback prototype' - a function which
takes all of the parameters you're going to pass. Parameters without a default
are to be passed positionally. Parameters with a default, or keyword-only
parameters on Python 3, are to be passed as keyword arguments. The prototype
doesn't need to do anything; only the signature is used.

::

    def msg_received_prototype(positional1, positional2, kw1=None, *, kw2):
        pass

Decorate your callback prototype with :func:`callback_prototype`:

.. autofunction:: callback_prototype

You can use the new ``adapt`` function to prepare callbacks when they are
registered with the callback API.

.. function:: prototype.adapt(callback)

   Inspects the signature of ``callback``. If it takes all of the arguments
   in ``prototype``, it is returned unmodified. If it takes a subset of those
   arguments, a wrapper is returned which will discard the extra arguments and
   call ``callback``. If it takes arguments not specified by the prototype,
   :exc:`TypeError` is raised.

Limitations
===========

* Callback functions can't have any extra arguments - even if they have default
  values, :func:`prototype.adapt` wants to match each argument to something in
  the prototype.
* The callback API can't specify that callbacks *must* take certain arguments.
  A function that takes no arguments is a valid callback anywhere.

Both of these limitations could be removed in a later version, but I want to see
what's important first.

* Callback functions must have introspectable signatures. Practically, this means
  functions defined in compiled code can't be used as callbacks without wrapping
  them in a Python function.

Signature introspection
=======================

backcall includes a backported copy of the Python 3.3+ :class:`inspect.Signature`
machinery to support Python 2.7. This was backported by `Min RK <https://github.com/minrk>`_
for IPython, and copied here.


Indices and tables
==================

* :ref:`genindex`
* :ref:`search`