summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorErlend E. Aasland <erlend.aasland@protonmail.com>2023-06-11 20:02:49 (GMT)
committerGitHub <noreply@github.com>2023-06-11 20:02:49 (GMT)
commit41cddc2e93a285b81fa30ac542b088bd9d0112e9 (patch)
tree327402188686f3424f35bfdee06895ef661e1095
parente8998e46a7ce8ad336e0941a6da6e50cb88d1e47 (diff)
downloadcpython-41cddc2e93a285b81fa30ac542b088bd9d0112e9.zip
cpython-41cddc2e93a285b81fa30ac542b088bd9d0112e9.tar.gz
cpython-41cddc2e93a285b81fa30ac542b088bd9d0112e9.tar.bz2
gh-105375: Improve error handling in the sys extension module (#105611)
In _PySys_AddXOptionWithError() and sys_add_xoption(), bail on first error to prevent exceptions from possibly being overwritten.
-rw-r--r--Misc/NEWS.d/next/Library/2023-06-09-23-46-23.gh-issue-105375.9KaioS.rst2
-rw-r--r--Python/sysmodule.c24
2 files changed, 20 insertions, 6 deletions
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 0000000..b12d7c8
--- /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 7027410..90e5e65 100644
--- a/Python/sysmodule.c
+++ b/Python/sysmodule.c
@@ -2721,14 +2721,20 @@ _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_NewRef(Py_True);
}
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;
@@ -3374,14 +3380,20 @@ 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_NewRef(Py_True);
}
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;