• Home
  • Line#
  • Scopes#
  • Navigate#
  • Raw
  • Download
1.. highlight:: c
2
3.. _call:
4
5Call Protocol
6=============
7
8CPython supports two different calling protocols:
9*tp_call* and vectorcall.
10
11The *tp_call* Protocol
12----------------------
13
14Instances of classes that set :c:member:`~PyTypeObject.tp_call` are callable.
15The signature of the slot is::
16
17    PyObject *tp_call(PyObject *callable, PyObject *args, PyObject *kwargs);
18
19A call is made using a tuple for the positional arguments
20and a dict for the keyword arguments, similarly to
21``callable(*args, **kwargs)`` in Python code.
22*args* must be non-NULL (use an empty tuple if there are no arguments)
23but *kwargs* may be *NULL* if there are no keyword arguments.
24
25This convention is not only used by *tp_call*:
26:c:member:`~PyTypeObject.tp_new` and :c:member:`~PyTypeObject.tp_init`
27also pass arguments this way.
28
29To call an object, use :c:func:`PyObject_Call` or other
30:ref:`call API <capi-call>`.
31
32
33.. _vectorcall:
34
35The Vectorcall Protocol
36-----------------------
37
38.. versionadded:: 3.9
39
40The vectorcall protocol was introduced in :pep:`590` as an additional protocol
41for making calls more efficient.
42
43As rule of thumb, CPython will prefer the vectorcall for internal calls
44if the callable supports it. However, this is not a hard rule.
45Additionally, some third-party extensions use *tp_call* directly
46(rather than using :c:func:`PyObject_Call`).
47Therefore, a class supporting vectorcall must also implement
48:c:member:`~PyTypeObject.tp_call`.
49Moreover, the callable must behave the same
50regardless of which protocol is used.
51The recommended way to achieve this is by setting
52:c:member:`~PyTypeObject.tp_call` to :c:func:`PyVectorcall_Call`.
53This bears repeating:
54
55.. warning::
56
57   A class supporting vectorcall **must** also implement
58   :c:member:`~PyTypeObject.tp_call` with the same semantics.
59
60A class should not implement vectorcall if that would be slower
61than *tp_call*. For example, if the callee needs to convert
62the arguments to an args tuple and kwargs dict anyway, then there is no point
63in implementing vectorcall.
64
65Classes can implement the vectorcall protocol by enabling the
66:const:`Py_TPFLAGS_HAVE_VECTORCALL` flag and setting
67:c:member:`~PyTypeObject.tp_vectorcall_offset` to the offset inside the
68object structure where a *vectorcallfunc* appears.
69This is a pointer to a function with the following signature:
70
71.. c:type:: PyObject *(*vectorcallfunc)(PyObject *callable, PyObject *const *args, size_t nargsf, PyObject *kwnames)
72
73- *callable* is the object being called.
74- *args* is a C array consisting of the positional arguments followed by the
75   values of the keyword arguments.
76   This can be *NULL* if there are no arguments.
77- *nargsf* is the number of positional arguments plus possibly the
78   :const:`PY_VECTORCALL_ARGUMENTS_OFFSET` flag.
79   To get the actual number of positional arguments from *nargsf*,
80   use :c:func:`PyVectorcall_NARGS`.
81- *kwnames* is a tuple containing the names of the keyword arguments;
82   in other words, the keys of the kwargs dict.
83   These names must be strings (instances of ``str`` or a subclass)
84   and they must be unique.
85   If there are no keyword arguments, then *kwnames* can instead be *NULL*.
86
87.. c:macro:: PY_VECTORCALL_ARGUMENTS_OFFSET
88
89   If this flag is set in a vectorcall *nargsf* argument, the callee is allowed
90   to temporarily change ``args[-1]``. In other words, *args* points to
91   argument 1 (not 0) in the allocated vector.
92   The callee must restore the value of ``args[-1]`` before returning.
93
94   For :c:func:`PyObject_VectorcallMethod`, this flag means instead that
95   ``args[0]`` may be changed.
96
97   Whenever they can do so cheaply (without additional allocation), callers
98   are encouraged to use :const:`PY_VECTORCALL_ARGUMENTS_OFFSET`.
99   Doing so will allow callables such as bound methods to make their onward
100   calls (which include a prepended *self* argument) very efficiently.
101
102To call an object that implements vectorcall, use a :ref:`call API <capi-call>`
103function as with any other callable.
104:c:func:`PyObject_Vectorcall` will usually be most efficient.
105
106
107.. note::
108
109   In CPython 3.8, the vectorcall API and related functions were available
110   provisionally under names with a leading underscore:
111   ``_PyObject_Vectorcall``, ``_Py_TPFLAGS_HAVE_VECTORCALL``,
112   ``_PyObject_VectorcallMethod``, ``_PyVectorcall_Function``,
113   ``_PyObject_CallOneArg``, ``_PyObject_CallMethodNoArgs``,
114   ``_PyObject_CallMethodOneArg``.
115   Additionally, ``PyObject_VectorcallDict`` was available as
116   ``_PyObject_FastCallDict``.
117   The old names are still defined as aliases of the new, non-underscored names.
118
119
120Recursion Control
121.................
122
123When using *tp_call*, callees do not need to worry about
124:ref:`recursion <recursion>`: CPython uses
125:c:func:`Py_EnterRecursiveCall` and :c:func:`Py_LeaveRecursiveCall`
126for calls made using *tp_call*.
127
128For efficiency, this is not the case for calls done using vectorcall:
129the callee should use *Py_EnterRecursiveCall* and *Py_LeaveRecursiveCall*
130if needed.
131
132
133Vectorcall Support API
134......................
135
136.. c:function:: Py_ssize_t PyVectorcall_NARGS(size_t nargsf)
137
138   Given a vectorcall *nargsf* argument, return the actual number of
139   arguments.
140   Currently equivalent to::
141
142      (Py_ssize_t)(nargsf & ~PY_VECTORCALL_ARGUMENTS_OFFSET)
143
144   However, the function ``PyVectorcall_NARGS`` should be used to allow
145   for future extensions.
146
147   This function is not part of the :ref:`limited API <stable>`.
148
149   .. versionadded:: 3.8
150
151.. c:function:: vectorcallfunc PyVectorcall_Function(PyObject *op)
152
153   If *op* does not support the vectorcall protocol (either because the type
154   does not or because the specific instance does not), return *NULL*.
155   Otherwise, return the vectorcall function pointer stored in *op*.
156   This function never raises an exception.
157
158   This is mostly useful to check whether or not *op* supports vectorcall,
159   which can be done by checking ``PyVectorcall_Function(op) != NULL``.
160
161   This function is not part of the :ref:`limited API <stable>`.
162
163   .. versionadded:: 3.8
164
165.. c:function:: PyObject* PyVectorcall_Call(PyObject *callable, PyObject *tuple, PyObject *dict)
166
167   Call *callable*'s :c:type:`vectorcallfunc` with positional and keyword
168   arguments given in a tuple and dict, respectively.
169
170   This is a specialized function, intended to be put in the
171   :c:member:`~PyTypeObject.tp_call` slot or be used in an implementation of ``tp_call``.
172   It does not check the :const:`Py_TPFLAGS_HAVE_VECTORCALL` flag
173   and it does not fall back to ``tp_call``.
174
175   This function is not part of the :ref:`limited API <stable>`.
176
177   .. versionadded:: 3.8
178
179
180.. _capi-call:
181
182Object Calling API
183------------------
184
185Various functions are available for calling a Python object.
186Each converts its arguments to a convention supported by the called object –
187either *tp_call* or vectorcall.
188In order to do as little conversion as possible, pick one that best fits
189the format of data you have available.
190
191The following table summarizes the available functions;
192please see individual documentation for details.
193
194+------------------------------------------+------------------+--------------------+---------------+
195| Function                                 | callable         | args               | kwargs        |
196+==========================================+==================+====================+===============+
197| :c:func:`PyObject_Call`                  | ``PyObject *``   | tuple              | dict/``NULL`` |
198+------------------------------------------+------------------+--------------------+---------------+
199| :c:func:`PyObject_CallNoArgs`            | ``PyObject *``   | ---                | ---           |
200+------------------------------------------+------------------+--------------------+---------------+
201| :c:func:`PyObject_CallOneArg`            | ``PyObject *``   | 1 object           | ---           |
202+------------------------------------------+------------------+--------------------+---------------+
203| :c:func:`PyObject_CallObject`            | ``PyObject *``   | tuple/``NULL``     | ---           |
204+------------------------------------------+------------------+--------------------+---------------+
205| :c:func:`PyObject_CallFunction`          | ``PyObject *``   | format             | ---           |
206+------------------------------------------+------------------+--------------------+---------------+
207| :c:func:`PyObject_CallMethod`            | obj + ``char*``  | format             | ---           |
208+------------------------------------------+------------------+--------------------+---------------+
209| :c:func:`PyObject_CallFunctionObjArgs`   | ``PyObject *``   | variadic           | ---           |
210+------------------------------------------+------------------+--------------------+---------------+
211| :c:func:`PyObject_CallMethodObjArgs`     | obj + name       | variadic           | ---           |
212+------------------------------------------+------------------+--------------------+---------------+
213| :c:func:`PyObject_CallMethodNoArgs`      | obj + name       | ---                | ---           |
214+------------------------------------------+------------------+--------------------+---------------+
215| :c:func:`PyObject_CallMethodOneArg`      | obj + name       | 1 object           | ---           |
216+------------------------------------------+------------------+--------------------+---------------+
217| :c:func:`PyObject_Vectorcall`            | ``PyObject *``   | vectorcall         | vectorcall    |
218+------------------------------------------+------------------+--------------------+---------------+
219| :c:func:`PyObject_VectorcallDict`        | ``PyObject *``   | vectorcall         | dict/``NULL`` |
220+------------------------------------------+------------------+--------------------+---------------+
221| :c:func:`PyObject_VectorcallMethod`      | arg + name       | vectorcall         | vectorcall    |
222+------------------------------------------+------------------+--------------------+---------------+
223
224
225.. c:function:: PyObject* PyObject_Call(PyObject *callable, PyObject *args, PyObject *kwargs)
226
227   Call a callable Python object *callable*, with arguments given by the
228   tuple *args*, and named arguments given by the dictionary *kwargs*.
229
230   *args* must not be *NULL*; use an empty tuple if no arguments are needed.
231   If no named arguments are needed, *kwargs* can be *NULL*.
232
233   Return the result of the call on success, or raise an exception and return
234   *NULL* on failure.
235
236   This is the equivalent of the Python expression:
237   ``callable(*args, **kwargs)``.
238
239
240.. c:function:: PyObject* PyObject_CallNoArgs(PyObject *callable)
241
242   Call a callable Python object *callable* without any arguments. It is the
243   most efficient way to call a callable Python object without any argument.
244
245   Return the result of the call on success, or raise an exception and return
246   *NULL* on failure.
247
248   .. versionadded:: 3.9
249
250
251.. c:function:: PyObject* PyObject_CallOneArg(PyObject *callable, PyObject *arg)
252
253   Call a callable Python object *callable* with exactly 1 positional argument
254   *arg* and no keyword arguments.
255
256   Return the result of the call on success, or raise an exception and return
257   *NULL* on failure.
258
259   This function is not part of the :ref:`limited API <stable>`.
260
261   .. versionadded:: 3.9
262
263
264.. c:function:: PyObject* PyObject_CallObject(PyObject *callable, PyObject *args)
265
266   Call a callable Python object *callable*, with arguments given by the
267   tuple *args*.  If no arguments are needed, then *args* can be *NULL*.
268
269   Return the result of the call on success, or raise an exception and return
270   *NULL* on failure.
271
272   This is the equivalent of the Python expression: ``callable(*args)``.
273
274
275.. c:function:: PyObject* PyObject_CallFunction(PyObject *callable, const char *format, ...)
276
277   Call a callable Python object *callable*, with a variable number of C arguments.
278   The C arguments are described using a :c:func:`Py_BuildValue` style format
279   string.  The format can be *NULL*, indicating that no arguments are provided.
280
281   Return the result of the call on success, or raise an exception and return
282   *NULL* on failure.
283
284   This is the equivalent of the Python expression: ``callable(*args)``.
285
286   Note that if you only pass :c:type:`PyObject *` args,
287   :c:func:`PyObject_CallFunctionObjArgs` is a faster alternative.
288
289   .. versionchanged:: 3.4
290      The type of *format* was changed from ``char *``.
291
292
293.. c:function:: PyObject* PyObject_CallMethod(PyObject *obj, const char *name, const char *format, ...)
294
295   Call the method named *name* of object *obj* with a variable number of C
296   arguments.  The C arguments are described by a :c:func:`Py_BuildValue` format
297   string that should produce a tuple.
298
299   The format can be *NULL*, indicating that no arguments are provided.
300
301   Return the result of the call on success, or raise an exception and return
302   *NULL* on failure.
303
304   This is the equivalent of the Python expression:
305   ``obj.name(arg1, arg2, ...)``.
306
307   Note that if you only pass :c:type:`PyObject *` args,
308   :c:func:`PyObject_CallMethodObjArgs` is a faster alternative.
309
310   .. versionchanged:: 3.4
311      The types of *name* and *format* were changed from ``char *``.
312
313
314.. c:function:: PyObject* PyObject_CallFunctionObjArgs(PyObject *callable, ...)
315
316   Call a callable Python object *callable*, with a variable number of
317   :c:type:`PyObject *` arguments.  The arguments are provided as a variable number
318   of parameters followed by *NULL*.
319
320   Return the result of the call on success, or raise an exception and return
321   *NULL* on failure.
322
323   This is the equivalent of the Python expression:
324   ``callable(arg1, arg2, ...)``.
325
326
327.. c:function:: PyObject* PyObject_CallMethodObjArgs(PyObject *obj, PyObject *name, ...)
328
329   Call a method of the Python object *obj*, where the name of the method is given as a
330   Python string object in *name*.  It is called with a variable number of
331   :c:type:`PyObject *` arguments.  The arguments are provided as a variable number
332   of parameters followed by *NULL*.
333
334   Return the result of the call on success, or raise an exception and return
335   *NULL* on failure.
336
337
338.. c:function:: PyObject* PyObject_CallMethodNoArgs(PyObject *obj, PyObject *name)
339
340   Call a method of the Python object *obj* without arguments,
341   where the name of the method is given as a Python string object in *name*.
342
343   Return the result of the call on success, or raise an exception and return
344   *NULL* on failure.
345
346   This function is not part of the :ref:`limited API <stable>`.
347
348   .. versionadded:: 3.9
349
350
351.. c:function:: PyObject* PyObject_CallMethodOneArg(PyObject *obj, PyObject *name, PyObject *arg)
352
353   Call a method of the Python object *obj* with a single positional argument
354   *arg*, where the name of the method is given as a Python string object in
355   *name*.
356
357   Return the result of the call on success, or raise an exception and return
358   *NULL* on failure.
359
360   This function is not part of the :ref:`limited API <stable>`.
361
362   .. versionadded:: 3.9
363
364
365.. c:function:: PyObject* PyObject_Vectorcall(PyObject *callable, PyObject *const *args, size_t nargsf, PyObject *kwnames)
366
367   Call a callable Python object *callable*.
368   The arguments are the same as for :c:type:`vectorcallfunc`.
369   If *callable* supports vectorcall_, this directly calls
370   the vectorcall function stored in *callable*.
371
372   Return the result of the call on success, or raise an exception and return
373   *NULL* on failure.
374
375   This function is not part of the :ref:`limited API <stable>`.
376
377   .. versionadded:: 3.9
378
379.. c:function:: PyObject* PyObject_VectorcallDict(PyObject *callable, PyObject *const *args, size_t nargsf, PyObject *kwdict)
380
381   Call *callable* with positional arguments passed exactly as in the vectorcall_ protocol,
382   but with keyword arguments passed as a dictionary *kwdict*.
383   The *args* array contains only the positional arguments.
384
385   Regardless of which protocol is used internally,
386   a conversion of arguments needs to be done.
387   Therefore, this function should only be used if the caller
388   already has a dictionary ready to use for the keyword arguments,
389   but not a tuple for the positional arguments.
390
391   This function is not part of the :ref:`limited API <stable>`.
392
393   .. versionadded:: 3.9
394
395.. c:function:: PyObject* PyObject_VectorcallMethod(PyObject *name, PyObject *const *args, size_t nargsf, PyObject *kwnames)
396
397   Call a method using the vectorcall calling convention. The name of the method
398   is given as a Python string *name*. The object whose method is called is
399   *args[0]*, and the *args* array starting at *args[1]* represents the arguments
400   of the call. There must be at least one positional argument.
401   *nargsf* is the number of positional arguments including *args[0]*,
402   plus :const:`PY_VECTORCALL_ARGUMENTS_OFFSET` if the value of ``args[0]`` may
403   temporarily be changed. Keyword arguments can be passed just like in
404   :c:func:`PyObject_Vectorcall`.
405
406   If the object has the :const:`Py_TPFLAGS_METHOD_DESCRIPTOR` feature,
407   this will call the unbound method object with the full
408   *args* vector as arguments.
409
410   Return the result of the call on success, or raise an exception and return
411   *NULL* on failure.
412
413   This function is not part of the :ref:`limited API <stable>`.
414
415   .. versionadded:: 3.9
416
417
418Call Support API
419----------------
420
421.. c:function:: int PyCallable_Check(PyObject *o)
422
423   Determine if the object *o* is callable.  Return ``1`` if the object is callable
424   and ``0`` otherwise.  This function always succeeds.
425