diff options
author | Victor Stinner <victor.stinner@gmail.com> | 2016-03-01 22:07:53 +0100 |
---|---|---|
committer | Victor Stinner <victor.stinner@gmail.com> | 2016-03-01 22:07:53 +0100 |
commit | f2192855dd16b3f5316599c47d958b3ccc2d3758 (patch) | |
tree | 3b96325f44c1b78325d81144c1e180c4b0194322 /Objects/unicodeobject.c | |
parent | 3d9d77a3dc1f38791e734f079afa2ed57b1278f9 (diff) | |
parent | 337986740f26ade866dbe79e35188f72caa8fe8d (diff) | |
download | cpython-git-f2192855dd16b3f5316599c47d958b3ccc2d3758.tar.gz |
Merge 3.5
Diffstat (limited to 'Objects/unicodeobject.c')
-rw-r--r-- | Objects/unicodeobject.c | 21 |
1 files changed, 12 insertions, 9 deletions
diff --git a/Objects/unicodeobject.c b/Objects/unicodeobject.c index c4cca6f91e..d0321baa24 100644 --- a/Objects/unicodeobject.c +++ b/Objects/unicodeobject.c @@ -8791,10 +8791,6 @@ unicode_fast_translate(PyObject *input, PyObject *mapping, Py_UCS1 *in, *end, *out; int res = 0; - if (PyUnicode_READY(input) == -1) - return -1; - if (!PyUnicode_IS_ASCII(input)) - return 0; len = PyUnicode_GET_LENGTH(input); memset(ascii_table, 0xff, 128); @@ -8877,13 +8873,20 @@ _PyUnicode_TranslateCharmap(PyObject *input, ignore = (errors != NULL && strcmp(errors, "ignore") == 0); - res = unicode_fast_translate(input, mapping, &writer, ignore, &i); - if (res < 0) { - _PyUnicodeWriter_Dealloc(&writer); + if (PyUnicode_READY(input) == -1) return NULL; + if (PyUnicode_IS_ASCII(input)) { + res = unicode_fast_translate(input, mapping, &writer, ignore, &i); + if (res < 0) { + _PyUnicodeWriter_Dealloc(&writer); + return NULL; + } + if (res == 1) + return _PyUnicodeWriter_Finish(&writer); + } + else { + i = 0; } - if (res == 1) - return _PyUnicodeWriter_Finish(&writer); while (i<size) { /* try to encode it */ |