Commit 3e90fa59 authored by Neal Norwitz's avatar Neal Norwitz

Try to cleanup the error handling a bit so there aren't false positives

from static analysis.  v was already checked for NULL above, so we don't
need a second check.
parent 4dc4a840
...@@ -206,7 +206,8 @@ do_mklist(const char **p_format, va_list *p_va, int endchar, int n) ...@@ -206,7 +206,8 @@ do_mklist(const char **p_format, va_list *p_va, int endchar, int n)
int itemfailed = 0; int itemfailed = 0;
if (n < 0) if (n < 0)
return NULL; return NULL;
if ((v = PyList_New(n)) == NULL) v = PyList_New(n);
if (v == NULL)
return NULL; return NULL;
/* Note that we can't bail immediately on error as this will leak /* Note that we can't bail immediately on error as this will leak
refcounts on any 'N' arguments. */ refcounts on any 'N' arguments. */
...@@ -219,18 +220,21 @@ do_mklist(const char **p_format, va_list *p_va, int endchar, int n) ...@@ -219,18 +220,21 @@ do_mklist(const char **p_format, va_list *p_va, int endchar, int n)
} }
PyList_SetItem(v, i, w); PyList_SetItem(v, i, w);
} }
if (v != NULL && **p_format != endchar) {
if (itemfailed) {
/* do_mkvalue() should have already set an error */
Py_DECREF(v);
return NULL;
}
if (**p_format != endchar) {
Py_DECREF(v); Py_DECREF(v);
v = NULL;
PyErr_SetString(PyExc_SystemError, PyErr_SetString(PyExc_SystemError,
"Unmatched paren in format"); "Unmatched paren in format");
return NULL;
} }
else if (endchar)
if (endchar)
++*p_format; ++*p_format;
if (itemfailed) {
Py_DECREF(v);
v = NULL;
}
return v; return v;
} }
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment