mirror of
https://github.com/python/cpython.git
synced 2025-11-01 18:51:43 +00:00
bpo-36946: Fix possible signed integer overflow when handling slices. (GH-13375)
The final addition (cur += step) may overflow, so use size_t for "cur". "cur" is always positive (even for negative steps), so it is safe to use size_t here. Co-Authored-By: Martin Panter <vadmium+py@gmail.com>
This commit is contained in:
parent
870b035bc6
commit
14514d9084
15 changed files with 45 additions and 19 deletions
|
|
@ -1809,7 +1809,8 @@ element_subscr(PyObject* self_, PyObject* item)
|
|||
return element_getitem(self_, i);
|
||||
}
|
||||
else if (PySlice_Check(item)) {
|
||||
Py_ssize_t start, stop, step, slicelen, cur, i;
|
||||
Py_ssize_t start, stop, step, slicelen, i;
|
||||
size_t cur;
|
||||
PyObject* list;
|
||||
|
||||
if (!self->extra)
|
||||
|
|
@ -1861,7 +1862,8 @@ element_ass_subscr(PyObject* self_, PyObject* item, PyObject* value)
|
|||
return element_setitem(self_, i, value);
|
||||
}
|
||||
else if (PySlice_Check(item)) {
|
||||
Py_ssize_t start, stop, step, slicelen, newlen, cur, i;
|
||||
Py_ssize_t start, stop, step, slicelen, newlen, i;
|
||||
size_t cur;
|
||||
|
||||
PyObject* recycle = NULL;
|
||||
PyObject* seq;
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue