summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorMiss Islington (bot) <31488909+miss-islington@users.noreply.github.com>2023-06-11 20:01:52 (GMT)
committerGitHub <noreply@github.com>2023-06-11 20:01:52 (GMT)
commit91877478ed68fd56934c699e03f81da9f4242d3c (patch)
treef6a50fe14abfee5c53ca9a937842e95b339087d7
parent05c73e1cd872843952f0e769265ec3d9535488f6 (diff)
downloadcpython-91877478ed68fd56934c699e03f81da9f4242d3c.zip
cpython-91877478ed68fd56934c699e03f81da9f4242d3c.tar.gz
cpython-91877478ed68fd56934c699e03f81da9f4242d3c.tar.bz2
[3.11] gh-105375: Improve error handling in PyUnicode_BuildEncodingMap() (GH-105491) (#105662)
Bail on first error to prevent exceptions from possibly being overwritten. (cherry picked from commit 555be81026fe1205d16c02f6321221381174cd07) Co-authored-by: Erlend E. Aasland <erlend.aasland@protonmail.com>
-rw-r--r--Misc/NEWS.d/next/Core and Builtins/2023-06-08-09-25-52.gh-issue-105375.ocB7fT.rst2
-rw-r--r--Objects/unicodeobject.c29
2 files changed, 19 insertions, 12 deletions
diff --git a/Misc/NEWS.d/next/Core and Builtins/2023-06-08-09-25-52.gh-issue-105375.ocB7fT.rst b/Misc/NEWS.d/next/Core and Builtins/2023-06-08-09-25-52.gh-issue-105375.ocB7fT.rst
new file mode 100644
index 0000000..24fac2d
--- /dev/null
+++ b/Misc/NEWS.d/next/Core and Builtins/2023-06-08-09-25-52.gh-issue-105375.ocB7fT.rst
@@ -0,0 +1,2 @@
+Improve error handling in :c:func:`PyUnicode_BuildEncodingMap` where an
+exception could end up being overwritten.
diff --git a/Objects/unicodeobject.c b/Objects/unicodeobject.c
index 4bdc8931..50deefe 100644
--- a/Objects/unicodeobject.c
+++ b/Objects/unicodeobject.c
@@ -8454,25 +8454,30 @@ PyUnicode_BuildEncodingMap(PyObject* string)
if (need_dict) {
PyObject *result = PyDict_New();
- PyObject *key, *value;
if (!result)
return NULL;
for (i = 0; i < length; i++) {
- key = PyLong_FromLong(PyUnicode_READ(kind, data, i));
- value = PyLong_FromLong(i);
- if (!key || !value)
- goto failed1;
- if (PyDict_SetItem(result, key, value) == -1)
- goto failed1;
+ Py_UCS4 c = PyUnicode_READ(kind, data, i);
+ PyObject *key = PyLong_FromLong(c);
+ if (key == NULL) {
+ Py_DECREF(result);
+ return NULL;
+ }
+ PyObject *value = PyLong_FromLong(i);
+ if (value == NULL) {
+ Py_DECREF(key);
+ Py_DECREF(result);
+ return NULL;
+ }
+ int rc = PyDict_SetItem(result, key, value);
Py_DECREF(key);
Py_DECREF(value);
+ if (rc < 0) {
+ Py_DECREF(result);
+ return NULL;
+ }
}
return result;
- failed1:
- Py_XDECREF(key);
- Py_XDECREF(value);
- Py_DECREF(result);
- return NULL;
}
/* Create a three-level trie */