]> granicus.if.org Git - python/commitdiff
Issue #18408: Fix parser.sequence2st() and parser.tuple2st(): raise MemoryError
authorVictor Stinner <victor.stinner@gmail.com>
Thu, 11 Jul 2013 23:33:59 +0000 (01:33 +0200)
committerVictor Stinner <victor.stinner@gmail.com>
Thu, 11 Jul 2013 23:33:59 +0000 (01:33 +0200)
on memory allocation failure

Instead of ignoring the memory allocation failure and create invalid objects.

Modules/parsermodule.c

index e86fe4d2eb58076a9cf944c3d72d8531852be83a..d2693e39561f10d0b33a1287f9ea226e30106fb9 100644 (file)
@@ -809,8 +809,13 @@ build_node_children(PyObject *tuple, node *root, int *line_num)
                 return 0;
             }
             strn = (char *)PyObject_MALLOC(len + 1);
-            if (strn != NULL)
-                (void) memcpy(strn, temp_str, len + 1);
+            if (strn == NULL) {
+                Py_DECREF(temp);
+                Py_XDECREF(elem);
+                PyErr_NoMemory();
+                return 0;
+            }
+            (void) memcpy(strn, temp_str, len + 1);
             Py_DECREF(temp);
         }
         else if (!ISNONTERMINAL(type)) {
@@ -906,8 +911,14 @@ build_node_tree(PyObject *tuple)
                     return NULL;
                 }
                 res->n_str = (char *)PyObject_MALLOC(len + 1);
-                if (res->n_str != NULL && temp != NULL)
-                    (void) memcpy(res->n_str, temp, len + 1);
+                if (res->n_str == NULL) {
+                    Py_DECREF(res);
+                    Py_DECREF(encoding);
+                    Py_DECREF(tuple);
+                    PyErr_NoMemory();
+                    return NULL;
+                }
+                (void) memcpy(res->n_str, temp, len + 1);
                 Py_DECREF(encoding);
                 Py_DECREF(tuple);
             }