From: Zackery Spytz Date: Thu, 12 Sep 2019 10:09:32 +0000 (-0600) Subject: closes bpo-38127: _ctypes: PyObject_IsSubclass() should be checked for failure. ... X-Git-Tag: v3.9.0a1~497 X-Git-Url: http://git.ipfire.org/gitweb.cgi?a=commitdiff_plain;h=ea683deccc505a78bbbb1eb8c6a88b0835ad5151;p=thirdparty%2FPython%2Fcpython.git closes bpo-38127: _ctypes: PyObject_IsSubclass() should be checked for failure. (GH-16011) An exception may occur during a PyObject_IsSubclass() call. --- diff --git a/Modules/_ctypes/_ctypes.c b/Modules/_ctypes/_ctypes.c index d2f6391fa6db..16a0cfe8dd4d 100644 --- a/Modules/_ctypes/_ctypes.c +++ b/Modules/_ctypes/_ctypes.c @@ -1168,7 +1168,11 @@ PyCPointerType_from_param(PyObject *type, PyObject *value) */ StgDictObject *v = PyObject_stgdict(value); assert(v); /* Cannot be NULL for pointer or array objects */ - if (PyObject_IsSubclass(v->proto, typedict->proto)) { + int ret = PyObject_IsSubclass(v->proto, typedict->proto); + if (ret < 0) { + return NULL; + } + if (ret) { Py_INCREF(value); return value; }