mirror of https://github.com/python/cpython
bpo-40170: PyType_SUPPORTS_WEAKREFS() becomes a regular function (GH-30938)
Convert the PyType_SUPPORTS_WEAKREFS() macro to a regular function. It no longer access the PyTypeObject.tp_weaklistoffset member directly. Add _PyType_SUPPORTS_WEAKREFS() static inline functions, used internally by Python for best performance.
This commit is contained in:
parent
f0a648152f
commit
af32b3ef1f
|
@ -91,7 +91,7 @@ PyAPI_FUNC(int) PyObject_IS_GC(PyObject *obj);
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
|
||||||
/* Test if a type supports weak references */
|
// Test if a type supports weak references
|
||||||
#define PyType_SUPPORTS_WEAKREFS(t) ((t)->tp_weaklistoffset > 0)
|
PyAPI_FUNC(int) PyType_SUPPORTS_WEAKREFS(PyTypeObject *type);
|
||||||
|
|
||||||
PyAPI_FUNC(PyObject **) PyObject_GET_WEAKREFS_LISTPTR(PyObject *op);
|
PyAPI_FUNC(PyObject **) PyObject_GET_WEAKREFS_LISTPTR(PyObject *op);
|
||||||
|
|
|
@ -200,6 +200,11 @@ extern int _Py_CheckSlotResult(
|
||||||
// See also the Py_TPFLAGS_READY flag.
|
// See also the Py_TPFLAGS_READY flag.
|
||||||
#define _PyType_IsReady(type) ((type)->tp_dict != NULL)
|
#define _PyType_IsReady(type) ((type)->tp_dict != NULL)
|
||||||
|
|
||||||
|
// Test if a type supports weak references
|
||||||
|
static inline int _PyType_SUPPORTS_WEAKREFS(PyTypeObject *type) {
|
||||||
|
return (type->tp_weaklistoffset > 0);
|
||||||
|
}
|
||||||
|
|
||||||
extern PyObject* _PyType_AllocNoTrack(PyTypeObject *type, Py_ssize_t nitems);
|
extern PyObject* _PyType_AllocNoTrack(PyTypeObject *type, Py_ssize_t nitems);
|
||||||
|
|
||||||
extern int _PyObject_InitializeDict(PyObject *obj);
|
extern int _PyObject_InitializeDict(PyObject *obj);
|
||||||
|
|
|
@ -28,7 +28,7 @@ _weakref_getweakrefcount_impl(PyObject *module, PyObject *object)
|
||||||
{
|
{
|
||||||
PyWeakReference **list;
|
PyWeakReference **list;
|
||||||
|
|
||||||
if (!PyType_SUPPORTS_WEAKREFS(Py_TYPE(object)))
|
if (!_PyType_SUPPORTS_WEAKREFS(Py_TYPE(object)))
|
||||||
return 0;
|
return 0;
|
||||||
|
|
||||||
list = GET_WEAKREFS_LISTPTR(object);
|
list = GET_WEAKREFS_LISTPTR(object);
|
||||||
|
@ -85,7 +85,7 @@ weakref_getweakrefs(PyObject *self, PyObject *object)
|
||||||
{
|
{
|
||||||
PyObject *result = NULL;
|
PyObject *result = NULL;
|
||||||
|
|
||||||
if (PyType_SUPPORTS_WEAKREFS(Py_TYPE(object))) {
|
if (_PyType_SUPPORTS_WEAKREFS(Py_TYPE(object))) {
|
||||||
PyWeakReference **list = GET_WEAKREFS_LISTPTR(object);
|
PyWeakReference **list = GET_WEAKREFS_LISTPTR(object);
|
||||||
Py_ssize_t count = _PyWeakref_GetWeakrefCount(*list);
|
Py_ssize_t count = _PyWeakref_GetWeakrefCount(*list);
|
||||||
|
|
||||||
|
|
|
@ -791,7 +791,7 @@ handle_weakrefs(PyGC_Head *unreachable, PyGC_Head *old)
|
||||||
_PyWeakref_ClearRef((PyWeakReference *)op);
|
_PyWeakref_ClearRef((PyWeakReference *)op);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (! PyType_SUPPORTS_WEAKREFS(Py_TYPE(op)))
|
if (! _PyType_SUPPORTS_WEAKREFS(Py_TYPE(op)))
|
||||||
continue;
|
continue;
|
||||||
|
|
||||||
/* It supports weakrefs. Does it have any? */
|
/* It supports weakrefs. Does it have any? */
|
||||||
|
|
|
@ -3729,7 +3729,7 @@ _PyErr_TrySetFromCause(const char *format, ...)
|
||||||
base_exc_size = _PyExc_BaseException.tp_basicsize;
|
base_exc_size = _PyExc_BaseException.tp_basicsize;
|
||||||
same_basic_size = (
|
same_basic_size = (
|
||||||
caught_type_size == base_exc_size ||
|
caught_type_size == base_exc_size ||
|
||||||
(PyType_SUPPORTS_WEAKREFS(caught_type) &&
|
(_PyType_SUPPORTS_WEAKREFS(caught_type) &&
|
||||||
(caught_type_size == base_exc_size + (Py_ssize_t)sizeof(PyObject *))
|
(caught_type_size == base_exc_size + (Py_ssize_t)sizeof(PyObject *))
|
||||||
)
|
)
|
||||||
);
|
);
|
||||||
|
|
|
@ -2473,12 +2473,21 @@ type_init(PyObject *cls, PyObject *args, PyObject *kwds)
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
unsigned long
|
unsigned long
|
||||||
PyType_GetFlags(PyTypeObject *type)
|
PyType_GetFlags(PyTypeObject *type)
|
||||||
{
|
{
|
||||||
return type->tp_flags;
|
return type->tp_flags;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
int
|
||||||
|
PyType_SUPPORTS_WEAKREFS(PyTypeObject *type)
|
||||||
|
{
|
||||||
|
return _PyType_SUPPORTS_WEAKREFS(type);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
/* Determine the most derived metatype. */
|
/* Determine the most derived metatype. */
|
||||||
PyTypeObject *
|
PyTypeObject *
|
||||||
_PyType_CalculateMetaclass(PyTypeObject *metatype, PyObject *bases)
|
_PyType_CalculateMetaclass(PyTypeObject *metatype, PyObject *bases)
|
||||||
|
|
|
@ -299,7 +299,7 @@ weakref___new__(PyTypeObject *type, PyObject *args, PyObject *kwargs)
|
||||||
PyWeakReference *ref, *proxy;
|
PyWeakReference *ref, *proxy;
|
||||||
PyWeakReference **list;
|
PyWeakReference **list;
|
||||||
|
|
||||||
if (!PyType_SUPPORTS_WEAKREFS(Py_TYPE(ob))) {
|
if (!_PyType_SUPPORTS_WEAKREFS(Py_TYPE(ob))) {
|
||||||
PyErr_Format(PyExc_TypeError,
|
PyErr_Format(PyExc_TypeError,
|
||||||
"cannot create weak reference to '%s' object",
|
"cannot create weak reference to '%s' object",
|
||||||
Py_TYPE(ob)->tp_name);
|
Py_TYPE(ob)->tp_name);
|
||||||
|
@ -794,7 +794,7 @@ PyWeakref_NewRef(PyObject *ob, PyObject *callback)
|
||||||
PyWeakReference **list;
|
PyWeakReference **list;
|
||||||
PyWeakReference *ref, *proxy;
|
PyWeakReference *ref, *proxy;
|
||||||
|
|
||||||
if (!PyType_SUPPORTS_WEAKREFS(Py_TYPE(ob))) {
|
if (!_PyType_SUPPORTS_WEAKREFS(Py_TYPE(ob))) {
|
||||||
PyErr_Format(PyExc_TypeError,
|
PyErr_Format(PyExc_TypeError,
|
||||||
"cannot create weak reference to '%s' object",
|
"cannot create weak reference to '%s' object",
|
||||||
Py_TYPE(ob)->tp_name);
|
Py_TYPE(ob)->tp_name);
|
||||||
|
@ -853,7 +853,7 @@ PyWeakref_NewProxy(PyObject *ob, PyObject *callback)
|
||||||
PyWeakReference **list;
|
PyWeakReference **list;
|
||||||
PyWeakReference *ref, *proxy;
|
PyWeakReference *ref, *proxy;
|
||||||
|
|
||||||
if (!PyType_SUPPORTS_WEAKREFS(Py_TYPE(ob))) {
|
if (!_PyType_SUPPORTS_WEAKREFS(Py_TYPE(ob))) {
|
||||||
PyErr_Format(PyExc_TypeError,
|
PyErr_Format(PyExc_TypeError,
|
||||||
"cannot create weak reference to '%s' object",
|
"cannot create weak reference to '%s' object",
|
||||||
Py_TYPE(ob)->tp_name);
|
Py_TYPE(ob)->tp_name);
|
||||||
|
@ -949,7 +949,7 @@ PyObject_ClearWeakRefs(PyObject *object)
|
||||||
PyWeakReference **list;
|
PyWeakReference **list;
|
||||||
|
|
||||||
if (object == NULL
|
if (object == NULL
|
||||||
|| !PyType_SUPPORTS_WEAKREFS(Py_TYPE(object))
|
|| !_PyType_SUPPORTS_WEAKREFS(Py_TYPE(object))
|
||||||
|| Py_REFCNT(object) != 0)
|
|| Py_REFCNT(object) != 0)
|
||||||
{
|
{
|
||||||
PyErr_BadInternalCall();
|
PyErr_BadInternalCall();
|
||||||
|
|
Loading…
Reference in New Issue