]> git.ipfire.org Git - thirdparty/Python/cpython.git/commitdiff
bpo-36150: Fix possible assertion failures due to _ctypes.c's PyCData_reduce(). ...
authorZackery Spytz <zspytz@gmail.com>
Sun, 31 Mar 2019 17:14:16 +0000 (11:14 -0600)
committerSerhiy Storchaka <storchaka@gmail.com>
Sun, 31 Mar 2019 17:14:16 +0000 (20:14 +0300)
(cherry picked from commit 5f2c50810a67982b0c80f6d3258fee3647f67005)

Modules/_ctypes/_ctypes.c

index 3a3aabbb6cb5968db5d623628eec53a1b70baefd..33e224386fb1fb5b0faf1a24b31989a486638ef4 100644 (file)
@@ -2795,16 +2795,18 @@ static PyObject *
 PyCData_reduce(PyObject *_self, PyObject *args)
 {
     CDataObject *self = (CDataObject *)_self;
+    PyObject *dict;
 
     if (PyObject_stgdict(_self)->flags & (TYPEFLAG_ISPOINTER|TYPEFLAG_HASPOINTER)) {
         PyErr_SetString(PyExc_ValueError,
                         "ctypes objects containing pointers cannot be pickled");
         return NULL;
     }
-    return Py_BuildValue("O(O(NN))",
-                         _unpickle,
-                         Py_TYPE(_self),
-                         PyObject_GetAttrString(_self, "__dict__"),
+    dict = PyObject_GetAttrString(_self, "__dict__");
+    if (dict == NULL) {
+        return NULL;
+    }
+    return Py_BuildValue("O(O(NN))", _unpickle, Py_TYPE(_self), dict,
                          PyString_FromStringAndSize(self->b_ptr, self->b_size));
 }