From: Erlend E. Aasland Date: Sun, 11 Jun 2023 21:08:40 +0000 (+0200) Subject: [3.11] gh-105375: Improve error handling in the sys extension module (#105611) (... X-Git-Tag: v3.11.5~285 X-Git-Url: http://git.ipfire.org/gitweb.cgi?a=commitdiff_plain;h=f98d475ee311268b28a9fc598a4efd22696d1208;p=thirdparty%2FPython%2Fcpython.git [3.11] gh-105375: Improve error handling in the sys extension module (#105611) (#105666) (cherry picked from commit 41cddc2e93a285b81fa30ac542b088bd9d0112e9) In _PySys_AddXOptionWithError() and sys_add_xoption(), bail on first error to prevent exceptions from possibly being overwritten. --- diff --git a/Misc/NEWS.d/next/Library/2023-06-09-23-46-23.gh-issue-105375.9KaioS.rst b/Misc/NEWS.d/next/Library/2023-06-09-23-46-23.gh-issue-105375.9KaioS.rst new file mode 100644 index 000000000000..b12d7c864e7b --- /dev/null +++ b/Misc/NEWS.d/next/Library/2023-06-09-23-46-23.gh-issue-105375.9KaioS.rst @@ -0,0 +1,2 @@ +Fix bugs in :mod:`sys` where exceptions could end up being overwritten +because of deferred error handling. diff --git a/Python/sysmodule.c b/Python/sysmodule.c index 8bab7037138d..84f17389559c 100644 --- a/Python/sysmodule.c +++ b/Python/sysmodule.c @@ -2360,15 +2360,21 @@ _PySys_AddXOptionWithError(const wchar_t *s) const wchar_t *name_end = wcschr(s, L'='); if (!name_end) { name = PyUnicode_FromWideChar(s, -1); + if (name == NULL) { + goto error; + } value = Py_True; Py_INCREF(value); } else { name = PyUnicode_FromWideChar(s, name_end - s); + if (name == NULL) { + goto error; + } value = PyUnicode_FromWideChar(name_end + 1, -1); - } - if (name == NULL || value == NULL) { - goto error; + if (value == NULL) { + goto error; + } } if (PyDict_SetItem(opts, name, value) < 0) { goto error; @@ -3019,15 +3025,21 @@ sys_add_xoption(PyObject *opts, const wchar_t *s) const wchar_t *name_end = wcschr(s, L'='); if (!name_end) { name = PyUnicode_FromWideChar(s, -1); + if (name == NULL) { + goto error; + } value = Py_True; Py_INCREF(value); } else { name = PyUnicode_FromWideChar(s, name_end - s); + if (name == NULL) { + goto error; + } value = PyUnicode_FromWideChar(name_end + 1, -1); - } - if (name == NULL || value == NULL) { - goto error; + if (value == NULL) { + goto error; + } } if (PyDict_SetItem(opts, name, value) < 0) { goto error;