summaryrefslogtreecommitdiffstats
path: root/Objects/unicodeobject.c
diff options
context:
space:
mode:
authorSerhiy Storchaka <storchaka@gmail.com>2016-10-25 10:23:56 (GMT)
committerSerhiy Storchaka <storchaka@gmail.com>2016-10-25 10:23:56 (GMT)
commitc8bc3d1c07e120ce4c887d618f9934e961453b3d (patch)
tree57dd73a983a17b01f7064bc926dfa49b82a46baf /Objects/unicodeobject.c
parentc3adf1e09b2cd981e4f3e07ef93c19c9513f4846 (diff)
downloadcpython-c8bc3d1c07e120ce4c887d618f9934e961453b3d.zip
cpython-c8bc3d1c07e120ce4c887d618f9934e961453b3d.tar.gz
cpython-c8bc3d1c07e120ce4c887d618f9934e961453b3d.tar.bz2
Issue #28408: Fixed a leak and remove redundant code in _PyUnicodeWriter_Finish().
Patch by Xiang Zhang.
Diffstat (limited to 'Objects/unicodeobject.c')
-rw-r--r--Objects/unicodeobject.c30
1 files changed, 12 insertions, 18 deletions
diff --git a/Objects/unicodeobject.c b/Objects/unicodeobject.c
index 4c95111..6cf5cb2 100644
--- a/Objects/unicodeobject.c
+++ b/Objects/unicodeobject.c
@@ -13570,34 +13570,28 @@ PyObject *
_PyUnicodeWriter_Finish(_PyUnicodeWriter *writer)
{
PyObject *str;
+
if (writer->pos == 0) {
Py_CLEAR(writer->buffer);
_Py_RETURN_UNICODE_EMPTY();
}
+
+ str = writer->buffer;
+ writer->buffer = NULL;
+
if (writer->readonly) {
- str = writer->buffer;
- writer->buffer = NULL;
assert(PyUnicode_GET_LENGTH(str) == writer->pos);
return str;
}
- if (writer->pos == 0) {
- Py_CLEAR(writer->buffer);
-
- /* Get the empty Unicode string singleton ('') */
- _Py_INCREF_UNICODE_EMPTY();
- str = unicode_empty;
- }
- else {
- str = writer->buffer;
- writer->buffer = NULL;
- if (PyUnicode_GET_LENGTH(str) != writer->pos) {
- PyObject *str2;
- str2 = resize_compact(str, writer->pos);
- if (str2 == NULL)
- return NULL;
- str = str2;
+ if (PyUnicode_GET_LENGTH(str) != writer->pos) {
+ PyObject *str2;
+ str2 = resize_compact(str, writer->pos);
+ if (str2 == NULL) {
+ Py_DECREF(str);
+ return NULL;
}
+ str = str2;
}
assert(_PyUnicode_CheckConsistency(str, 1));