diff options
author | Serhiy Storchaka <storchaka@gmail.com> | 2018-07-23 20:43:42 (GMT) |
---|---|---|
committer | GitHub <noreply@github.com> | 2018-07-23 20:43:42 (GMT) |
commit | a6fdddb7df00aefad2ec6e362dbf10d4bd8bff32 (patch) | |
tree | b2e4079b9488323d34b95459452cbcec6b4480fe /Objects | |
parent | aba24ff3601ddc86b85e01880a8be596fb799287 (diff) | |
download | cpython-a6fdddb7df00aefad2ec6e362dbf10d4bd8bff32.zip cpython-a6fdddb7df00aefad2ec6e362dbf10d4bd8bff32.tar.gz cpython-a6fdddb7df00aefad2ec6e362dbf10d4bd8bff32.tar.bz2 |
bpo-32500: Fix error messages for sequence and mapping C API. (GH-7846)
Fix error messages for PySequence_Size(), PySequence_GetItem(),
PySequence_SetItem() and PySequence_DelItem() called with a mapping
and PyMapping_Size() called with a sequence.
Diffstat (limited to 'Objects')
-rw-r--r-- | Objects/abstract.c | 20 |
1 files changed, 20 insertions, 0 deletions
diff --git a/Objects/abstract.c b/Objects/abstract.c index 192ade1..8d3030a 100644 --- a/Objects/abstract.c +++ b/Objects/abstract.c @@ -1531,6 +1531,10 @@ PySequence_Size(PyObject *s) return len; } + if (s->ob_type->tp_as_mapping && s->ob_type->tp_as_mapping->mp_length) { + type_error("%.200s is not a sequence", s); + return -1; + } type_error("object of type '%.200s' has no len()", s); return -1; } @@ -1677,6 +1681,9 @@ PySequence_GetItem(PyObject *s, Py_ssize_t i) return m->sq_item(s, i); } + if (s->ob_type->tp_as_mapping && s->ob_type->tp_as_mapping->mp_subscript) { + return type_error("%.200s is not a sequence", s); + } return type_error("'%.200s' object does not support indexing", s); } @@ -1728,6 +1735,10 @@ PySequence_SetItem(PyObject *s, Py_ssize_t i, PyObject *o) return m->sq_ass_item(s, i, o); } + if (s->ob_type->tp_as_mapping && s->ob_type->tp_as_mapping->mp_ass_subscript) { + type_error("%.200s is not a sequence", s); + return -1; + } type_error("'%.200s' object does not support item assignment", s); return -1; } @@ -1757,6 +1768,10 @@ PySequence_DelItem(PyObject *s, Py_ssize_t i) return m->sq_ass_item(s, i, (PyObject *)NULL); } + if (s->ob_type->tp_as_mapping && s->ob_type->tp_as_mapping->mp_ass_subscript) { + type_error("%.200s is not a sequence", s); + return -1; + } type_error("'%.200s' object doesn't support item deletion", s); return -1; } @@ -2093,6 +2108,11 @@ PyMapping_Size(PyObject *o) return len; } + if (o->ob_type->tp_as_sequence && o->ob_type->tp_as_sequence->sq_length) { + type_error("%.200s is not a mapping", o); + return -1; + } + /* PyMapping_Size() can be called from PyObject_Size(). */ type_error("object of type '%.200s' has no len()", o); return -1; } |