Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
C
cpython
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
0
Merge Requests
0
Analytics
Analytics
Repository
Value Stream
Wiki
Wiki
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Commits
Issue Boards
Open sidebar
Kirill Smelkov
cpython
Commits
5600b5e1
Commit
5600b5e1
authored
Jun 16, 2019
by
Jeroen Demeyer
Committed by
Inada Naoki
Jun 17, 2019
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
bpo-28805: document METH_FASTCALL (GH-14079)
parent
2dfeaa92
Changes
2
Show whitespace changes
Inline
Side-by-side
Showing
2 changed files
with
52 additions
and
12 deletions
+52
-12
Doc/c-api/structures.rst
Doc/c-api/structures.rst
+51
-12
Misc/NEWS.d/next/C API/2019-06-14-14-03-51.bpo-28805.qZC0N_.rst
...EWS.d/next/C API/2019-06-14-14-03-51.bpo-28805.qZC0N_.rst
+1
-0
No files found.
Doc/c-api/structures.rst
View file @
5600b5e1
...
@@ -114,10 +114,20 @@ the definition of all other Python objects.
...
@@ -114,10 +114,20 @@ the definition of all other Python objects.
.. c:type:: PyCFunctionWithKeywords
.. c:type:: PyCFunctionWithKeywords
Type of the functions used to implement Python callables in C that take
Type of the functions used to implement Python callables in C
keyword arguments: they take three :c:type:`PyObject\*` parameters and return
with signature :const:`METH_VARARGS | METH_KEYWORDS`.
one such value. See :c:type:`PyCFunction` above for the meaning of the return
value.
.. c:type:: _PyCFunctionFast
Type of the functions used to implement Python callables in C
with signature :const:`METH_FASTCALL`.
.. c:type:: _PyCFunctionFastWithKeywords
Type of the functions used to implement Python callables in C
with signature :const:`METH_FASTCALL | METH_KEYWORDS`.
.. c:type:: PyMethodDef
.. c:type:: PyMethodDef
...
@@ -149,10 +159,11 @@ specific C type of the *self* object.
...
@@ -149,10 +159,11 @@ specific C type of the *self* object.
The :attr:`ml_flags` field is a bitfield which can include the following flags.
The :attr:`ml_flags` field is a bitfield which can include the following flags.
The individual flags indicate either a calling convention or a binding
The individual flags indicate either a calling convention or a binding
convention. Of the calling convention flags, only :const:`METH_VARARGS` and
convention.
:const:`METH_KEYWORDS` can be combined. Any of the calling convention flags
can be combined with a binding flag.
There are four basic calling conventions for positional arguments
and two of them can be combined with :const:`METH_KEYWORDS` to support
also keyword arguments. So there are a total of 6 calling conventions:
.. data:: METH_VARARGS
.. data:: METH_VARARGS
...
@@ -164,13 +175,41 @@ can be combined with a binding flag.
...
@@ -164,13 +175,41 @@ can be combined with a binding flag.
using :c:func:`PyArg_ParseTuple` or :c:func:`PyArg_UnpackTuple`.
using :c:func:`PyArg_ParseTuple` or :c:func:`PyArg_UnpackTuple`.
.. data:: METH_KEYWORDS
.. data:: METH_
VARARGS | METH_
KEYWORDS
Methods with these flags must be of type :c:type:`PyCFunctionWithKeywords`.
Methods with these flags must be of type :c:type:`PyCFunctionWithKeywords`.
The function expects three parameters: *self*, *args*, and a dictionary of
The function expects three parameters: *self*, *args*, *kwargs* where
all the keyword arguments. The flag must be combined with
*kwargs* is a dictionary of all the keyword arguments or possibly *NULL*
:const:`METH_VARARGS`, and the parameters are typically processed using
if there are no keyword arguments. The parameters are typically processed
:c:func:`PyArg_ParseTupleAndKeywords`.
using :c:func:`PyArg_ParseTupleAndKeywords`.
.. data:: METH_FASTCALL
Fast calling convention supporting only positional arguments.
The methods have the type :c:type:`_PyCFunctionFast`.
The first parameter is *self*, the second parameter is a C array
of :c:type:`PyObject\*` values indicating the arguments and the third
parameter is the number of arguments (the length of the array).
This is not part of the :ref:`limited API <stable>`.
.. versionadded:: 3.7
.. data:: METH_FASTCALL | METH_KEYWORDS
Extension of :const:`METH_FASTCALL` supporting also keyword arguments,
with methods of type :c:type:`_PyCFunctionFastWithKeywords`.
Keyword arguments are passed the same way as in the vectorcall protocol:
there is an additional fourth :c:type:`PyObject\*` parameter
which is a tuple representing the names of the keyword arguments
or possibly *NULL* if there are no keywords. The values of the keyword
arguments are stored in the *args* array, after the positional arguments.
This is not part of the :ref:`limited API <stable>`.
.. versionadded:: 3.7
.. data:: METH_NOARGS
.. data:: METH_NOARGS
...
...
Misc/NEWS.d/next/C API/2019-06-14-14-03-51.bpo-28805.qZC0N_.rst
0 → 100644
View file @
5600b5e1
The :const:`METH_FASTCALL` calling convention has been documented.
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment