]> git.ipfire.org Git - thirdparty/Python/cpython.git/commitdiff
bpo-44378: Fix a compiler warning in Py_IS_TYPE() (GH-26644)
authorMiss Islington (bot) <31488909+miss-islington@users.noreply.github.com>
Fri, 11 Jun 2021 08:57:16 +0000 (01:57 -0700)
committerGitHub <noreply@github.com>
Fri, 11 Jun 2021 08:57:16 +0000 (01:57 -0700)
Py_IS_TYPE() no longer uses Py_TYPE() to avoid a compiler warning:
no longer cast "const PyObject*" to "PyObject*".
(cherry picked from commit 304dfec8d3c0763734ea8b5fa2af1d9e1ce69ffa)

Co-authored-by: Victor Stinner <vstinner@python.org>
Include/object.h
Misc/NEWS.d/next/C API/2021-06-10-15-22-31.bpo-44378.jGYakF.rst [new file with mode: 0644]

index 4c069998574b4a39f432b108e1741329cc677e73..109f535249cda81d42ab8403031d294e9ae1ea5c 100644 (file)
@@ -141,7 +141,9 @@ static inline Py_ssize_t _Py_REFCNT(const PyObject *ob) {
 
 
 static inline int _Py_IS_TYPE(const PyObject *ob, const PyTypeObject *type) {
-    return Py_TYPE(ob) == type;
+    // bpo-44378: Don't use Py_TYPE() since Py_TYPE() requires a non-const
+    // object.
+    return ob->ob_type == type;
 }
 #define Py_IS_TYPE(ob, type) _Py_IS_TYPE(_PyObject_CAST_CONST(ob), type)
 
diff --git a/Misc/NEWS.d/next/C API/2021-06-10-15-22-31.bpo-44378.jGYakF.rst b/Misc/NEWS.d/next/C API/2021-06-10-15-22-31.bpo-44378.jGYakF.rst
new file mode 100644 (file)
index 0000000..b620b49
--- /dev/null
@@ -0,0 +1,3 @@
+:c:func:`Py_IS_TYPE` no longer uses :c:func:`Py_TYPE` to avoid a compiler
+warning: no longer cast ``const PyObject*`` to ``PyObject*``.
+Patch by Victor Stinner.