mirror of
https://github.com/python/cpython.git
synced 2025-07-15 23:35:23 +00:00
Partial revert of changeset 9744b2df134c
PyUnicode_Append() cannot call directly resize_compact(): I forgot that a string can be ready *and* not compact (a legacy string can also be ready).
This commit is contained in:
parent
fb161b1b6d
commit
bb4503f61e
1 changed files with 4 additions and 5 deletions
|
@ -10748,12 +10748,11 @@ PyUnicode_Append(PyObject **p_left, PyObject *right)
|
|||
&& !(PyUnicode_IS_ASCII(left) && !PyUnicode_IS_ASCII(right)))
|
||||
{
|
||||
/* append inplace */
|
||||
res = resize_compact(left, new_len);
|
||||
if (res == NULL)
|
||||
if (unicode_resize(p_left, new_len) != 0)
|
||||
goto error;
|
||||
|
||||
/* copy 'right' into the newly allocated area of 'res' (left) */
|
||||
_PyUnicode_FastCopyCharacters(res, left_len, right, 0, right_len);
|
||||
/* copy 'right' into the newly allocated area of 'left' */
|
||||
_PyUnicode_FastCopyCharacters(*p_left, left_len, right, 0, right_len);
|
||||
}
|
||||
else {
|
||||
maxchar = PyUnicode_MAX_CHAR_VALUE(left);
|
||||
|
@ -10767,8 +10766,8 @@ PyUnicode_Append(PyObject **p_left, PyObject *right)
|
|||
_PyUnicode_FastCopyCharacters(res, 0, left, 0, left_len);
|
||||
_PyUnicode_FastCopyCharacters(res, left_len, right, 0, right_len);
|
||||
Py_DECREF(left);
|
||||
*p_left = res;
|
||||
}
|
||||
*p_left = res;
|
||||
assert(_PyUnicode_CheckConsistency(*p_left, 1));
|
||||
return;
|
||||
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue