blob: ea0b59a8447e65583cdbe1f35db2c7cacffb35bf [file]
/* Helpers related to Python object type
Copyright (C) 2026 Free Software Foundation, Inc.
This file is part of GDB.
This program is free software; you can redistribute it and/or modify
it under the terms of the GNU General Public License as published by
the Free Software Foundation; either version 3 of the License, or
(at your option) any later version.
This program is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
GNU General Public License for more details.
You should have received a copy of the GNU General Public License
along with this program. If not, see <http://www.gnu.org/licenses/>. */
#include "python-internal.h"
#include "py-obj-type.h"
/* Return the type's fully qualified name from a PyTypeObject. */
const char *
gdb_py_tp_name (PyTypeObject *py_type) noexcept
{
#if PY_VERSION_HEX >= 0x030d0000
/* Note: PyType_GetFullyQualifiedName() was added in version 3.13, and is
part of the stable ABI since version 3.13. */
PyObject *fully_qualified_name = PyType_GetFullyQualifiedName (py_type);
if (fully_qualified_name == nullptr)
return nullptr;
return PyUnicode_AsUTF8AndSize (fully_qualified_name, nullptr);
#else /* PY_VERSION_HEX < 0x030d0000 && ! defined (Py_LIMITED_API) */
/* For non-heap types, the fully qualified name corresponds to tp_name. */
if (! (PyType_GetFlags (py_type) & Py_TPFLAGS_HEAPTYPE))
return py_type->tp_name;
/* In the absence of PyType_GetFullyQualifiedName(), we fallback using
__qualname__ instead. However, the result may differ slightly in some
cases, e.g. the module name may be missing. */
# if PY_VERSION_HEX >= 0x030b0000
/* Note: PyType_GetQualName() was added in version 3.11. */
PyObject *qualname = PyType_GetQualName (py_type);
if (qualname == nullptr)
return nullptr;
return PyUnicode_AsUTF8AndSize (qualname, nullptr);
# else
/* In the absence of PyType_GetQualName(), fallback on using PyHeapTypeObject
which is not part of the public API.
Tested on 3.10 which is the oldest supported version at the time of this
writing, i.e. February 2026. Hopefully, this workaround should go away
when the minimum supported Python version is increased above 3.10. */
PyHeapTypeObject *ht = (PyHeapTypeObject *) py_type;
if (ht->ht_qualname == nullptr)
return nullptr;
return PyUnicode_AsUTF8AndSize (ht->ht_qualname, nullptr);
# endif
#endif
}
/* Return the type's fully qualified name from a PyObject. */
const char *
gdbpy_py_obj_tp_name (PyObject *self) noexcept
{
/* Note: Py_TYPE () is part of the stable ABI since version 3.14. */
return gdb_py_tp_name (Py_TYPE (self));
}