]> granicus.if.org Git - python/commitdiff
Issue #18408: Fix array_tolist(), handle PyList_SetItem() failure
authorVictor Stinner <victor.stinner@gmail.com>
Wed, 17 Jul 2013 23:12:35 +0000 (01:12 +0200)
committerVictor Stinner <victor.stinner@gmail.com>
Wed, 17 Jul 2013 23:12:35 +0000 (01:12 +0200)
Modules/arraymodule.c

index 6b37cacafeb9c1d5556737671e07b4968e667c24..f5706ddc417e0be21e0499d654a65b30915ea07c 100644 (file)
@@ -1027,7 +1027,7 @@ array_contains(arrayobject *self, PyObject *v)
     for (i = 0, cmp = 0 ; cmp == 0 && i < Py_SIZE(self); i++) {
         PyObject *selfi = getarrayitem((PyObject *)self, i);
         if (selfi == NULL)
-            return NULL;
+            return -1;
         cmp = PyObject_RichCompareBool(selfi, v, Py_EQ);
         Py_DECREF(selfi);
     }
@@ -1405,13 +1405,16 @@ array_tolist(arrayobject *self, PyObject *unused)
         return NULL;
     for (i = 0; i < Py_SIZE(self); i++) {
         PyObject *v = getarrayitem((PyObject *)self, i);
-        if (v == NULL) {
-            Py_DECREF(list);
-            return NULL;
-        }
-        PyList_SetItem(list, i, v);
+        if (v == NULL)
+            goto error;
+        if (PyList_SetItem(list, i, v) < 0)
+            goto error;
     }
     return list;
+
+error:
+    Py_DECREF(list);
+    return NULL;
 }
 
 PyDoc_STRVAR(tolist_doc,