summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorSerhiy Storchaka <storchaka@gmail.com>2017-09-08 07:43:54 (GMT)
committerGitHub <noreply@github.com>2017-09-08 07:43:54 (GMT)
commitddb536ba7b7c6022424e39d666c3cc81772645c0 (patch)
tree48ba8d3f97ac4b4b060c910db81cf48bb16ba896
parent9f2b3d4c2899f9caea2e47063061a76e460ac618 (diff)
downloadcpython-ddb536ba7b7c6022424e39d666c3cc81772645c0.zip
cpython-ddb536ba7b7c6022424e39d666c3cc81772645c0.tar.gz
cpython-ddb536ba7b7c6022424e39d666c3cc81772645c0.tar.bz2
[3.6] bpo-31393: Fix the use of PyUnicode_READY(). (GH-3451). (#3453)
(cherry picked from commit e3b2b4b8d9e751b49e3550cb83ba39b54fdc377c)
-rw-r--r--Modules/socketmodule.c5
-rw-r--r--Objects/codeobject.c7
-rw-r--r--Objects/typeobject.c6
-rw-r--r--Objects/unicodeobject.c10
-rw-r--r--Python/ceval.c17
5 files changed, 30 insertions, 15 deletions
diff --git a/Modules/socketmodule.c b/Modules/socketmodule.c
index d006bd4..a351faa 100644
--- a/Modules/socketmodule.c
+++ b/Modules/socketmodule.c
@@ -1464,7 +1464,10 @@ idna_converter(PyObject *obj, struct maybe_idna *data)
len = PyByteArray_Size(obj);
}
else if (PyUnicode_Check(obj)) {
- if (PyUnicode_READY(obj) == 0 && PyUnicode_IS_COMPACT_ASCII(obj)) {
+ if (PyUnicode_READY(obj) == -1) {
+ return 0;
+ }
+ if (PyUnicode_IS_COMPACT_ASCII(obj)) {
data->buf = PyUnicode_DATA(obj);
len = PyUnicode_GET_LENGTH(obj);
}
diff --git a/Objects/codeobject.c b/Objects/codeobject.c
index 6de697a..d45be4c 100644
--- a/Objects/codeobject.c
+++ b/Objects/codeobject.c
@@ -22,8 +22,7 @@ all_name_chars(PyObject *o)
static const unsigned char *name_chars = (unsigned char *)NAME_CHARS;
const unsigned char *s, *e;
- if (!PyUnicode_Check(o) || PyUnicode_READY(o) == -1 ||
- !PyUnicode_IS_ASCII(o))
+ if (!PyUnicode_IS_ASCII(o))
return 0;
if (ok_name_char[*name_chars] == 0) {
@@ -64,6 +63,10 @@ intern_string_constants(PyObject *tuple)
for (i = PyTuple_GET_SIZE(tuple); --i >= 0; ) {
PyObject *v = PyTuple_GET_ITEM(tuple, i);
if (PyUnicode_CheckExact(v)) {
+ if (PyUnicode_READY(v) == -1) {
+ PyErr_Clear();
+ continue;
+ }
if (all_name_chars(v)) {
PyObject *w = v;
PyUnicode_InternInPlace(&v);
diff --git a/Objects/typeobject.c b/Objects/typeobject.c
index 271b935..cb5e235 100644
--- a/Objects/typeobject.c
+++ b/Objects/typeobject.c
@@ -22,9 +22,9 @@
#define MCACHE_HASH_METHOD(type, name) \
MCACHE_HASH((type)->tp_version_tag, \
((PyASCIIObject *)(name))->hash)
-#define MCACHE_CACHEABLE_NAME(name) \
- PyUnicode_CheckExact(name) && \
- PyUnicode_READY(name) != -1 && \
+#define MCACHE_CACHEABLE_NAME(name) \
+ PyUnicode_CheckExact(name) && \
+ PyUnicode_IS_READY(name) && \
PyUnicode_GET_LENGTH(name) <= MCACHE_MAX_ATTR_SIZE
struct method_cache_entry {
diff --git a/Objects/unicodeobject.c b/Objects/unicodeobject.c
index 1650370..1f221af 100644
--- a/Objects/unicodeobject.c
+++ b/Objects/unicodeobject.c
@@ -4210,10 +4210,13 @@ PyUnicode_ReadChar(PyObject *unicode, Py_ssize_t index)
void *data;
int kind;
- if (!PyUnicode_Check(unicode) || PyUnicode_READY(unicode) == -1) {
+ if (!PyUnicode_Check(unicode)) {
PyErr_BadArgument();
return (Py_UCS4)-1;
}
+ if (PyUnicode_READY(unicode) == -1) {
+ return (Py_UCS4)-1;
+ }
if (index < 0 || index >= PyUnicode_GET_LENGTH(unicode)) {
PyErr_SetString(PyExc_IndexError, "string index out of range");
return (Py_UCS4)-1;
@@ -11706,10 +11709,13 @@ unicode_getitem(PyObject *self, Py_ssize_t index)
enum PyUnicode_Kind kind;
Py_UCS4 ch;
- if (!PyUnicode_Check(self) || PyUnicode_READY(self) == -1) {
+ if (!PyUnicode_Check(self)) {
PyErr_BadArgument();
return NULL;
}
+ if (PyUnicode_READY(self) == -1) {
+ return NULL;
+ }
if (index < 0 || index >= PyUnicode_GET_LENGTH(self)) {
PyErr_SetString(PyExc_IndexError, "string index out of range");
return NULL;
diff --git a/Python/ceval.c b/Python/ceval.c
index 4aa3250..2b74d0e 100644
--- a/Python/ceval.c
+++ b/Python/ceval.c
@@ -5307,13 +5307,16 @@ import_all_from(PyObject *locals, PyObject *v)
PyErr_Clear();
break;
}
- if (skip_leading_underscores &&
- PyUnicode_Check(name) &&
- PyUnicode_READY(name) != -1 &&
- PyUnicode_READ_CHAR(name, 0) == '_')
- {
- Py_DECREF(name);
- continue;
+ if (skip_leading_underscores && PyUnicode_Check(name)) {
+ if (PyUnicode_READY(name) == -1) {
+ Py_DECREF(name);
+ err = -1;
+ break;
+ }
+ if (PyUnicode_READ_CHAR(name, 0) == '_') {
+ Py_DECREF(name);
+ continue;
+ }
}
value = PyObject_GetAttr(v, name);
if (value == NULL)