]> granicus.if.org Git - python/commitdiff
closes bpo-38127: _ctypes: PyObject_IsSubclass() should be checked for failure. ...
authorMiss Islington (bot) <31488909+miss-islington@users.noreply.github.com>
Thu, 12 Sep 2019 10:28:05 +0000 (03:28 -0700)
committerGitHub <noreply@github.com>
Thu, 12 Sep 2019 10:28:05 +0000 (03:28 -0700)
An exception may occur during a PyObject_IsSubclass() call.
(cherry picked from commit ea683deccc505a78bbbb1eb8c6a88b0835ad5151)

Co-authored-by: Zackery Spytz <zspytz@gmail.com>
Modules/_ctypes/_ctypes.c

index 47288740063e8f11fb8287632f65d750fc3690b4..0f11e01e111056821b57effcd6c99864dcd2f477 100644 (file)
@@ -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;
         }