summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorVictor Stinner <victor.stinner@haypocalc.com>2011-12-11 19:04:56 (GMT)
committerVictor Stinner <victor.stinner@haypocalc.com>2011-12-11 19:04:56 (GMT)
commit84def3774d2079ea2a812e0220507ff0e27247e7 (patch)
tree1a11f75e529fdd56b0901cc1c35ce7f1091f40c5
parent8bbe788deb774d066e8d185b1af04af3b4537dfc (diff)
downloadcpython-84def3774d2079ea2a812e0220507ff0e27247e7.zip
cpython-84def3774d2079ea2a812e0220507ff0e27247e7.tar.gz
cpython-84def3774d2079ea2a812e0220507ff0e27247e7.tar.bz2
Fix error handling in resize_compact()
-rw-r--r--Objects/unicodeobject.c14
1 files changed, 9 insertions, 5 deletions
diff --git a/Objects/unicodeobject.c b/Objects/unicodeobject.c
index 9670ae8..2846bd2 100644
--- a/Objects/unicodeobject.c
+++ b/Objects/unicodeobject.c
@@ -630,6 +630,7 @@ resize_compact(PyObject *unicode, Py_ssize_t length)
Py_ssize_t struct_size;
Py_ssize_t new_size;
int share_wstr;
+ PyObject *new_unicode;
assert(PyUnicode_IS_READY(unicode));
char_size = PyUnicode_KIND(unicode);
@@ -639,22 +640,25 @@ resize_compact(PyObject *unicode, Py_ssize_t length)
struct_size = sizeof(PyCompactUnicodeObject);
share_wstr = _PyUnicode_SHARE_WSTR(unicode);
- _Py_DEC_REFTOTAL;
- _Py_ForgetReference(unicode);
-
if (length > ((PY_SSIZE_T_MAX - struct_size) / char_size - 1)) {
+ Py_DECREF(unicode);
PyErr_NoMemory();
return NULL;
}
new_size = (struct_size + (length + 1) * char_size);
- unicode = (PyObject *)PyObject_REALLOC((char *)unicode, new_size);
- if (unicode == NULL) {
+ _Py_DEC_REFTOTAL;
+ _Py_ForgetReference(unicode);
+
+ new_unicode = (PyObject *)PyObject_REALLOC((char *)unicode, new_size);
+ if (new_unicode == NULL) {
PyObject_Del(unicode);
PyErr_NoMemory();
return NULL;
}
+ unicode = new_unicode;
_Py_NewReference(unicode);
+
_PyUnicode_LENGTH(unicode) = length;
if (share_wstr) {
_PyUnicode_WSTR(unicode) = PyUnicode_DATA(unicode);