From 7fc39a21cb85163a456eab91b52e5fe85e7f7e3e Mon Sep 17 00:00:00 2001 From: Victor Stinner Date: Thu, 31 Mar 2022 10:03:13 +0200 Subject: bpo-47164: Add _PyCFunctionObject_CAST() macr (GH-32190) Add _PyCFunctionObject_CAST() and _PyCMethodObject_CAST() macros to make macros casting their argument easier to read, but also to check the type of their input in debug mode: assert(PyCFunction_Check(func) and assert(PyCMethod_Check(func). Reformat also PyCFunction_XXX() macros for readability. --- Include/cpython/methodobject.h | 17 +++++++++++------ 1 file changed, 11 insertions(+), 6 deletions(-) diff --git a/Include/cpython/methodobject.h b/Include/cpython/methodobject.h index 7ecbfe3..46d1777 100644 --- a/Include/cpython/methodobject.h +++ b/Include/cpython/methodobject.h @@ -7,18 +7,23 @@ PyAPI_DATA(PyTypeObject) PyCMethod_Type; #define PyCMethod_CheckExact(op) Py_IS_TYPE(op, &PyCMethod_Type) #define PyCMethod_Check(op) PyObject_TypeCheck(op, &PyCMethod_Type) +#define _PyCFunctionObject_CAST(func) \ + (assert(PyCFunction_Check(func)), (PyCFunctionObject *)(func)) +#define _PyCMethodObject_CAST(func) \ + (assert(PyCMethod_Check(func)), (PyCMethodObject *)(func)) + /* Macros for direct access to these values. Type checks are *not* done, so use with care. */ #define PyCFunction_GET_FUNCTION(func) \ - (((PyCFunctionObject *)func) -> m_ml -> ml_meth) + (_PyCFunctionObject_CAST(func)->m_ml->ml_meth) #define PyCFunction_GET_SELF(func) \ - (((PyCFunctionObject *)func) -> m_ml -> ml_flags & METH_STATIC ? \ - NULL : ((PyCFunctionObject *)func) -> m_self) + (_PyCFunctionObject_CAST(func)->m_ml->ml_flags & METH_STATIC ? \ + NULL : _PyCFunctionObject_CAST(func)->m_self) #define PyCFunction_GET_FLAGS(func) \ - (((PyCFunctionObject *)func) -> m_ml -> ml_flags) + (_PyCFunctionObject_CAST(func)->m_ml->ml_flags) #define PyCFunction_GET_CLASS(func) \ - (((PyCFunctionObject *)func) -> m_ml -> ml_flags & METH_METHOD ? \ - ((PyCMethodObject *)func) -> mm_class : NULL) + (_PyCFunctionObject_CAST(func)->m_ml->ml_flags & METH_METHOD ? \ + _PyCMethodObject_CAST(func)->mm_class : NULL) typedef struct { PyObject_HEAD -- cgit v0.12