mirror of
https://github.com/python/cpython.git
synced 2026-01-04 06:22:20 +00:00
bpo-33738: Fix macros which contradict PEP 384 (GH-7477)
During development of the limited API support for PySide,
we saw an error in a macro that accessed a type field.
This patch fixes the 7 errors in the Python headers.
Macros which were not written as capitals were implemented
as function.
To do the necessary analysis again, a script was included that
parses all headers and looks for "->tp_" in serctions which can
be reached with active limited API.
It is easily possible to call this script as a test.
Error listing:
../../Include/objimpl.h:243
#define PyObject_IS_GC(o) (PyType_IS_GC(Py_TYPE(o)) && \
(Py_TYPE(o)->tp_is_gc == NULL || Py_TYPE(o)->tp_is_gc(o)))
Action: commented only
../../Include/objimpl.h:362
#define PyType_SUPPORTS_WEAKREFS(t) ((t)->tp_weaklistoffset > 0)
Action: commented only
../../Include/objimpl.h:364
#define PyObject_GET_WEAKREFS_LISTPTR(o) \
((PyObject **) (((char *) (o)) + Py_TYPE(o)->tp_weaklistoffset))
Action: commented only
../../Include/pyerrors.h:143
#define PyExceptionClass_Name(x) \
((char *)(((PyTypeObject*)(x))->tp_name))
Action: implemented function
../../Include/abstract.h:593
#define PyIter_Check(obj) \
((obj)->ob_type->tp_iternext != NULL && \
(obj)->ob_type->tp_iternext != &_PyObject_NextNotImplemented)
Action: implemented function
../../Include/abstract.h:713
#define PyIndex_Check(obj) \
((obj)->ob_type->tp_as_number != NULL && \
(obj)->ob_type->tp_as_number->nb_index != NULL)
Action: implemented function
../../Include/abstract.h:924
#define PySequence_ITEM(o, i)\
( Py_TYPE(o)->tp_as_sequence->sq_item(o, i) )
Action: commented only
This commit is contained in:
parent
3f45f5da8e
commit
ea62ce7f4f
8 changed files with 198 additions and 0 deletions
|
|
@ -248,6 +248,7 @@ EXPORTS
|
|||
PyExc_Warning=python38.PyExc_Warning DATA
|
||||
PyExc_WindowsError=python38.PyExc_WindowsError DATA
|
||||
PyExc_ZeroDivisionError=python38.PyExc_ZeroDivisionError DATA
|
||||
PyExceptionClass_Name=python38.PyExceptionClass_Name
|
||||
PyException_GetCause=python38.PyException_GetCause
|
||||
PyException_GetContext=python38.PyException_GetContext
|
||||
PyException_GetTraceback=python38.PyException_GetTraceback
|
||||
|
|
@ -294,9 +295,11 @@ EXPORTS
|
|||
PyImport_ImportModuleLevelObject=python38.PyImport_ImportModuleLevelObject
|
||||
PyImport_ImportModuleNoBlock=python38.PyImport_ImportModuleNoBlock
|
||||
PyImport_ReloadModule=python38.PyImport_ReloadModule
|
||||
PyIndex_Check=python38.PyIndex_Check
|
||||
PyInterpreterState_Clear=python38.PyInterpreterState_Clear
|
||||
PyInterpreterState_Delete=python38.PyInterpreterState_Delete
|
||||
PyInterpreterState_New=python38.PyInterpreterState_New
|
||||
PyIter_Check=python38.PyIter_Check
|
||||
PyIter_Next=python38.PyIter_Next
|
||||
PyListIter_Type=python38.PyListIter_Type DATA
|
||||
PyListRevIter_Type=python38.PyListRevIter_Type DATA
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue