]> granicus.if.org Git - python/commitdiff
Partial revert of changeset 9744b2df134c
authorVictor Stinner <victor.stinner@gmail.com>
Thu, 18 Apr 2013 07:41:34 +0000 (09:41 +0200)
committerVictor Stinner <victor.stinner@gmail.com>
Thu, 18 Apr 2013 07:41:34 +0000 (09:41 +0200)
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).

Objects/unicodeobject.c

index 076674c68bb512542173bb20ef8264a23d996f3e..4c532afc3e9403733c7ab1873e2cb0dd9d4f0b63 100644 (file)
@@ -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;